$.getJSON 发生界面跳转-yellowcong

$.getJSON的使用过程中,发生了很奇葩很不解的问题,发送请求后AJAX的数据直接被填充到了服务器端,郁闷死本宝宝了,后来发现是ajax请求配置了全局的操作,设置了同步请求和error处理操作,ajax的全局设定是不可以被覆盖的,所以不要想着覆盖这个ajaxError 方法

ajax 的函数

通过ajaxStart和ajaxStop这两个方法,可以做界面请求的时候,不可以操作界面

//当一个当Ajax请求开始时将把id为"loading"的内容显示;
$("#loading").ajaxStart(
             function(){  
                    $(this).show(); //callback 
            }
 );

//:当一个当Ajax请求结束时将把id为"loading"的内容隐藏;
$("#loading").ajaxStop(
    function(){  
        $(this).hide(); 
        //call 
        }
 );

问题产生位置

大家看下面的代码,是ajax请求设定的共同操作,这些操作都是基于全局的,导致我界面跳转的是ajaxError这个破玩意,我发送的请求正常处理,反回200的状态吗,然后他居然跳转到error处理,然后把我界面数据都给干掉了,妈蛋

// ajaxの初期化
$.ajaxSetup( {
    type: 'post',
    dataType: 'json',
    global: true,
    async: true,
});

//ajaxStart 开始
$(document).ajaxStart(function() {

});

//ajaxStop 结束
$(document).ajaxStop(function() {
    sofia.ui.dispLoader(false);
});

// ajaxError错误处理
$(document).ajaxError(function(event, XMLHttpRequest, options, thrownError){

    var status = XMLHttpRequest.status;
    var json = XMLHttpRequest.responseJSON;
    //判断反回来结果
    switch (status) {

        case 200:
            //  :root是选择文档的根元素 ,将根节点的数据替换成反悔的数据了
            $(":root").replaceWith(XMLHttpRequest.responseText);
            break;

        case 400:
            // 
            console.log(json.message, undefined);
            break;

        case 500:
            console.log(json.message, undefined);
            break;

        default:
            alert("status: " + status);
    }
});
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

狂飙的yellowcong

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值