javascript - ExtJs:ajax 调用中的代码执行顺序是什么?

标签 javascript ajax extjs asynchronous single-threaded

鉴于 Javascript 是单线程语言,ExtJs 中以下代码的执行顺序是什么?

FuncA();

Ext.Ajax.request({
    url: 'ajax.php',
    params: {
        id: 1
    },
    success: function(response){

        FuncB();
    }
});

FuncC();

FuncD();

这里函数的执行顺序是A-C-D-B吗?

或者

是否有可能在 FuncC() 或 FuncD() 之前调用 FuncB()?如果是,那么在什么条件下?

在此先感谢您的帮助。

最佳答案

除非 ajax 请求是同步的,否则顺序将始终为 A-C-D-B,但实际上不建议使用它,因为它会导致 UI 挂起。

例如,试试这个(最好在 Chrome 中)

function f1() {
    var s = '';
    for (var i = 0; i < 10000000; ++i) {
        s += 'a';
    }
}

function f2() {
    var s = '';
    for (var i = 0; i < 10000000; ++i) {
        s += 'b';
    }
}

Ext.require('Ext.Ajax');

Ext.onReady(function() {

    var d;
    Ext.Ajax.request({
        url: 'data.json',
        success: function(){
            console.log('finished');
        }
    });

    d = new Date();
    f1();
    console.log(new Date() - d, 'f1 done');
    d = new Date();
    f2();
    console.log(new Date() - d, 'f2 done');

});

您会看到,即使运行代码大约需要 1 秒,ajax 请求总是最后触发,即使请求本身只需要大约 7 毫秒(它是一个本地框)。然后通过注释掉对 f1/f2 的调用再试一次。

关于javascript - ExtJs:ajax 调用中的代码执行顺序是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10398035/

相关文章:

extjs - 网格单元格中的工具提示 - ExtJs 6

javascript - JS Q 库 - 延迟错误捕获

javascript - 'npm start' 上的 React JS 奇数错误无法解析源映射

javascript - react 助焊剂 : Store dependencies

javascript - 当 html 元素在用户屏幕上可见时执行 ajax

javascript - 在 Sencha Touch selectfield 中填充图标

Extjs htmleditor获取光标位置

javascript - 如何从数据库填充下拉菜单项

javascript - 使用 onClick 和 React AutoBind

javascript - 在我的 AJAX 应用程序中拦截对后退按钮的调用