首页 > 代码库 > Ajax请求全局配置
Ajax请求全局配置
摘要:
jQuery已经成为项目中最常见的js库,也是前端开发最喜欢使用的库。下面是在项目中封装了jQuery的Ajax,分享给大家。
代码:
// ajax 请求参数var ajaxSettings = function(opt) { var url = opt.url; var href =http://www.mamicode.com/ location.href; // 判断是否跨域请求 var requestType = ‘jsonp‘; if (url.indexOf(location.host) > -1) requestType = ‘json‘; requestType = opt.dataType || requestType; // 是否异步请求 var async = (opt.async === undefined ? true : opt.async); return { url: url, async: async, type: opt.type || ‘get‘, dataType: requestType, cache: false, data: opt.data, success: function(data, textStatus, xhr) { /* *如果dataType是json,怎判断返回数据是否为json格式,如果不是进行转换 * 成功数据通用格式 * { * "code": 200, * "data": [], * "success": true // 成功 * } * 失败返回的数据 * { * "code": 200, * "info": ‘error‘, * "success": false // 失败 * } */ if((requestType === ‘json‘ || requestType === "jsonp") && typeof(data) === "string") { data = JSON.parse(data); } if(data.success) { opt.success(data); } if(opt.error) { opt.error(data); } }, error: function(xhr, status, handler) { if (opt.error) opt.error(); } };};function unescapeEntity(str) { var reg = /&(?:nbsp|#160|lt|#60|gt|62|amp|#38|quot|#34|cent|#162|pound|#163|yen|#165|euro|#8364|sect|#167|copy|#169|reg|#174|trade|#8482|times|#215|divide|#247);/g, entity = { ‘ ‘ : ‘ ‘, ‘ ‘ : ‘ ‘, ‘<‘ : ‘<‘, ‘<‘ : ‘<‘, ‘>‘ : ‘>‘, ‘&62;‘ : ‘>‘, ‘&‘ : ‘&‘, ‘&‘ : ‘&‘, ‘"‘ : ‘"‘, ‘"‘ : ‘"‘, ‘¢‘ : ‘¢‘, ‘¢‘ : ‘¢‘, ‘£‘ : ‘£‘, ‘£‘ : ‘£‘, ‘¥‘ : ‘¥‘, ‘¥‘ : ‘¥‘, ‘€‘ : ‘€‘, ‘€‘ : ‘€‘, ‘§‘ : ‘§‘, ‘§‘ : ‘§‘, ‘©‘ : ‘©‘, ‘©‘ : ‘©‘, ‘®‘ : ‘®‘, ‘®‘ : ‘®‘, ‘™‘ : ‘™‘, ‘™‘ : ‘™‘, ‘ב : ‘ב, ‘ב : ‘ב, ‘÷‘ : ‘÷‘, ‘÷‘ : ‘÷‘ }; if (str === null) { return ‘‘; } str = str.toString(); return str.indexOf(‘;‘) < 0 ? str : str.replace(reg, function(chars) { return entity[chars]; });}// 转换html的实体$.ajaxSetup({ global : true, cache : false, converters : { ‘text json‘ : function(response){ return jQuery.parseJSON(unescapeEntity(response)); } }});/**Ajax 请求权限异常* 用户权限错误跳转登陆页* 404错误跳转404页面 */$(document).ajaxComplete(function(evt, req, settings){ if(req && req.responseJSON){ var json = req.responseJSON; if(json.code === 403 && json.info === ‘perm error‘ && !json.success){ window.location.href = location.protocol + ‘//‘ + location.hostname; return; } if(json.code === 404 && !json.success) { window.location.href = location.protocol + ‘//‘ + location.hostname + ‘/404.html‘; } }});/**Ajax 请求错误提示*例如:500错误*返回错误信息格式*{* code: 500,* info: 系统发生异常*} */$(document).ajaxError(function(evt, req, settings){ if(req && (req.status === 200||req.status === 0)){ return false; } var msg = ‘错误:‘; if(req && req.responseJSON){ var json = req.responseJSON; msg += json.code||‘‘; msg += json.info||‘系统异常,请重试‘; }else{ msg = ‘系统异常,请重试‘; } alert(msg);});
小结:
在执行Ajax请求时只需要调用ajaxSettings函数即可,如下:
$.ajax(ajaxSettings({ url: ‘‘, data: ‘‘}))
Ajax请求全局配置
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。