search

Home  >  Q&A  >  body text

关于JavaScript的异步加载问题

这样引入一个JavaScript:

<script type="text/javascript" async src="//somedomain.com/somefile.js"></script>

这里用到了async,在使用这个脚本的时候,如果同时执行其它操作,如:

$("p.foo").click(function(){
  // 1. 运行和引用的somefile.js有关的事件
  // 2. 窗体跳转
});

在这个过程中,期待按顺序执行1和2,实际上却是有时先执行1,有时先执行2,这个异步加载如何处理能达到希望的效果呢?

伊谢尔伦伊谢尔伦2822 days ago504

reply all(3)I'll reply

  • 大家讲道理

    大家讲道理2017-04-10 13:12:12

    用jquery.getscript, script加载后的逻辑 写入回调函数。 自己读文档吧:
    http://api.jquery.com/jquery.getscript/

    reply
    0
  • PHP中文网

    PHP中文网2017-04-10 13:12:12

    简单的做法是建议考虑在script载入完成后再绑定。

    <script type="text/javascript" async src="//somedomain.com/somefile.js" onload="bindClick"></script>
    
    function bindClick(){
      $("p.foo").click(function(){
        // 1. 运行和引用的somefile.js有关的事件
        // 2. 窗体跳转
      });
    }
    

    reply
    0
  • 怪我咯

    怪我咯2017-04-10 13:12:12

    在比较复杂的系统里,通常采用模块化开发,比如你的somefile.js就作为一个模块,在文件内部暴露某些方法和变量,然后在somefile.js模块加载完成后进行相关操作。以sea.js为例:
    somefile.js:

    define(function(require, exports, module) {
            exports.foo = function() { //暴露foo方法
                //todo
            };
    });
    

    index.html:

    其实现原理和一楼说的基本类似,另外,如果你关注js的执行顺序,同时又不希望js下载时阻塞html的解析,那么可以使用defer而非async,这两者的区别可以参考以下网址:http://peter.sh/experiments/asynchronous-and-deferred-javascript-execution-explained/

    reply
    0
  • Cancelreply