午夜国产狂喷潮在线观看|国产AⅤ精品一区二区久久|中文字幕AV中文字幕|国产看片高清在线

    封裝了jQuery的Ajax請求全局配置
    來源:易賢網(wǎng) 閱讀:1877 次 日期:2015-02-06 15:01:37
    溫馨提示:易賢網(wǎng)小編為您整理了“封裝了jQuery的Ajax請求全局配置”,方便廣大網(wǎng)友查閱!

    摘要:

    jQuery已經(jīng)成為項目中最常見的js庫,也是前端開發(fā)最喜歡使用的庫。下面是在項目中封裝了jQuery的Ajax,分享給大家。

    代碼:

    代碼如下:

    // ajax 請求參數(shù)

    var ajaxSettings = function(opt) {

    var url = opt.url;

    var href = 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,怎判斷返回數(shù)據(jù)是否為json格式,如果不是進行轉(zhuǎn)換

    * 成功數(shù)據(jù)通用格式

    * {

    * "code": 200,

    * "data": [],

    * "success": true // 成功

    * }

    * 失敗返回的數(shù)據(jù)

    * {

    * "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];

    });

    }

    // 轉(zhuǎn)換html的實體

    $.ajaxSetup({

    global : true,

    cache : false,

    converters : {

    'text json' : function(response){

    return jQuery.parseJSON(unescapeEntity(response));

    }

    }

    });

    /*

    *Ajax 請求權(quán)限異常

    * 用戶權(quán)限錯誤跳轉(zhuǎn)登陸頁

    * 404錯誤跳轉(zhuǎn)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: 系統(tǒng)發(fā)生異常

    *}

    */

    $(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||'系統(tǒng)異常,請重試';

    }else{

    msg = '系統(tǒng)異常,請重試';

    }

    alert(msg);

    });

    小結(jié):

    在執(zhí)行Ajax請求時只需要調(diào)用ajaxSettings函數(shù)即可,如下:

    代碼如下:

    $.ajax(ajaxSettings({

    url: '',

    data: ''

    }))

    以上所述就是本文的全部內(nèi)容了,希望大家能夠喜歡。

    更多信息請查看IT技術(shù)專欄

    更多信息請查看腳本欄目
    易賢網(wǎng)手機網(wǎng)站地址:封裝了jQuery的Ajax請求全局配置
    由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!

    2025國考·省考課程試聽報名

    • 報班類型
    • 姓名
    • 手機號
    • 驗證碼
    關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
    工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號
    云南網(wǎng)警備案專用圖標(biāo)
    聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號:hfpxwx
    咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
    云南網(wǎng)警報警專用圖標(biāo)