调用ajax的一种套路

Posted anthonyliu

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了调用ajax的一种套路相关的知识,希望对你有一定的参考价值。

function n(e) {
    if (exports.emit("pick", "success"),!A) {
        if (e.fields && Array.isArray(e.fields))
            S.ack = e.ack || S.ack,
            e.fields.forEach(function(e) {
                if (w[e.command])
                    w[e.command](e)
            }
            );
        if (!A)
            exports.emit("pick", "response", {
                status: 0,
                bid: S.bid,
                session: S.session,
                seq: S.seq,
                ack: S.ack
            })
    }
}
function r(e) {
    if (exports.emit("pick", "failure"),"offline" == e || "kicked" == e)
        exports.emit("error", "stop");
    else if (!A)
        exports.emit("pick", "response", {
            status: 1,
            bid: S.bid,
            session: S.session,
            seq: S.seq,
            ack: S.ack
        })
}
function o() {
    //超时操作
    exports.emit("pick", "timeout"),
    clearTimeout(y);
    var e = v;
    //  e为发出去的XMLHttpRequest对象
    if (v = null ,e.abort(),!v)
        a() //轮询a();重新去取数据。
}
//为什么要通过i封装一次,原因是提供统一接口。
function i(e, t, i, n, r) {
    if ("function" == typeof i)
        r = n,
        n = i;
    if (e == g.TYPE_HI)
        i = i || {},
        i.session = S.session,
        i.seq = S.seq++;
    //调用ajax,也是对ajax的封装
    return g.get(e, t, i, n, r)
}
function s(e, t) {
    return function() {
        var i = Array.prototype.slice.call(arguments);
        //闭包来判断私有静态变量b与返回的数据进行对比
        if (e === b) {
            //有返回,清除y。
            if (v = null ,clearTimeout(y),"success" == t)
                //调用成功
                n.apply(null , i);
            else
                //调用失败
                r.apply(null , i);
            //A初始时为false
            if (!A)
                setTimeout(function() {
                    a()       
                }
                , 0)
        }
    }
}
function a() {
    if (!v)                            //v初始为NULL
        b++,                           //b初始为0
        v = i(g.TYPE_HI, "pick", {
                imuss: S.bid,
                ucid: S.ucid,
                ack: S.ack || ""
            }, 
            //这里的b传递到回调函数中。
            s(b, "success"), s(b, "failure")),
        //对发出的请求超时监控
        y = setTimeout(o, C.PICK_TIMEOUT)
}

 

以上是关于调用ajax的一种套路的主要内容,如果未能解决你的问题,请参考以下文章

从活动中调用片段事件

PHP AJAX的套路

html 输入类型提交通常在单击时重新加载页面。此片段使输入不重新加载页面以便进行ajax调用

链接中的 URL 片段和 JSF 中的 ajax 重定向

是否对同源域的 ajax 调用进行了预检请求?

使用 Jquery 的同步“Ajax”调用似乎不起作用