在AJAX调用未完成时停止JS函数执行

时间:2012-01-18 11:29:12

标签: javascript jquery

我写了一个小函数来动态包含CSS文件或JS文件。 我用jquery函数$.getScript()加载JS文件。

我希望在AJAX调用完成之前阻止我的函数返回。

我尝试了类似的东西,但它不起作用:

CAPTIVEA.resources._includeResource = function(resource) {
    var ret = false;

    if (CAPTIVEA.resources.isIncluded(resource))
    {   // Resource already included => do nothing
        console.log('CAPTIVEA.resources : "' + resource + '" is already included.');
        ret = true;
    }
    else
    {   // Resource not included => try to include it
        var resType = CAPTIVEA.resources.getType(resource);
        switch (resType)
        {   // Check resource type to know how to include it
            case 'js':
                $.when(
                    $.getScript(resource, function(data, textStatus){
                        console.info('CAPTIVEA.resources : "' + resource + '" dynamically loaded.'); //success
                    })
                ).done(function(){
                    ret = true;
                });
                break;
            case 'css':
                // Load CSS file ...
                break;
            default:
                console.error('CAPTIVEA.resources : "' + resource + '" is not an includable resource.');
                break;
        }
    }

    return ret;
}

3 个答案:

答案 0 :(得分:5)

您可以使用$ .ajax并将async设置为false,以便在继续之前等待响应:

$.ajax({
   url: resource,
   success: function(data, textStatus) {
                        console.info('CAPTIVEA.resources : "' + resource + '" dynamically loaded.'); //success
   },
   dataType: 'script',
   async: false
});

答案 1 :(得分:1)

使用通常不需要同步调用。 AJAX的全部意义在于它是异步的。第一个 A 代表异步

为什么需要阻止你的功能返回?通常是因为你想在加载时使用资源(在这种情况下是脚本)。你必须改为使用回调:

WRONG:

$.getScript(resource);
doSomethingWithResource();

RIGHT:

$.getScript(resource, function() {
  doSomethingWithResource();
});

答案 2 :(得分:-1)

试试这个:

CAPTIVEA.resources._includeResource = function(resource) {
    var ret = false;

    if (CAPTIVEA.resources.isIncluded(resource))
    {   // Resource already included => do nothing
        console.log('CAPTIVEA.resources : "' + resource + '" is already included.');
        ret = true;
    }
    else
    {   // Resource not included => try to include it
        var resType = CAPTIVEA.resources.getType(resource);
        successFlag = false;
        switch (resType)
        {   // Check resource type to know how to include it
            case 'js':
                jQuery.ajax({
                    async:false,
                    type:'POST',
                    url: resource,
                    data: null,
                    success: function(){successFlag =true;}
                });
                break;
            case 'css':
                // Load CSS file ...
                break;
            default:
                console.error('CAPTIVEA.resources : "' + resource + '" is not an includable resource.');
                break;
        }
        ret = successFlag;
    }

    return ret;
}

我认为它是唯一的解决方案,即使我们必须添加一个全局变量(successFlag)。另一种解决方案就是在你的成功回调中做你必须做的事情,但这样你的功能就不会像你期望的那样工作。