微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

javascript – 执行从.each()同步返回的脚本,但没有按顺序完成

情况是我从API动态加载一组脚本,然后通过eval()调用.我不关心调用脚本的顺序,但我不希望同时调用它们中的任何一个.也就是说,脚本A,B和C可以按顺序返回C,B,A,并且我想在返回C时立即开始eval(C),但我希望eval(B)等到eval(C)完成了.

没有进入完全毛茸茸的代码,这里是“实例”是字符串数组的核心.

$.each(instances,function( index,instance ) {
    var apiUrl = "http://the-api-url.com/" + instance;
    $.getJSON(apiUrl,function(data) {
        // except I don't want to eval here as evaluations may overlap
        eval(data.script);
    });
});

根据我的理解,我可以使用.when()等待所有内容完成,但这会浪费时间,因为我不需要等到所有内容都下载才能开始执行.

解决方法

你的问题有点不清楚,但假设脚本可以按任何顺序执行(A,C,C等),那么你不需要改变任何东西.

Javascript(在浏览器中)是单线程的,因此传递给$.getJSON的回调将按顺序进行调度.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐