找回密码
 立即注册
首页 业界区 业界 [原创]如何确保JavaScript的执行顺序 – 之jQuery.html ...

[原创]如何确保JavaScript的执行顺序 – 之jQuery.html深度分析

神泱 2025-5-29 15:38:19
上一篇:[原创]如何确保JavaScript的执行顺序 – 之实战篇1.      引言

在上一篇文章《如何确保JavaScript的执行顺序 - 之实战篇》中,我们发现jQuery的html函数能够确保动态加载的JavaScript按照引入顺序执行。
 
我们先来简单回顾下HTML源代码(test2.htm):


   

   

   



   

   



 
2.      调试,单步跟进

逐行分析jQuery源代码是一件相当枯燥的事情。我这里会以test2.htm为目标,调试进入jQuery源代码。
1)     首先在html: 打一个断点,刷新页面


这里的value是字符串:""
 
我们来看会进入那个条件分支:首先看看rnocache是啥?

可见value中含有 ​
, ​]

 
evalScript,这是一个函数,通过jQuery.each函数来调用,上述数组中的每个值都会作为参数传到这个函数中执行:
function evalScript( i, elem ) {

     if ( elem.src ) {

              jQuery.ajax({

                       url: elem.src,

                       async: false,

                       dataType: "script"

              });

     } else {

              jQuery.globalEval( elem.text || elem.textContent || elem.innerHTML || "" );

     }

     if ( elem.parentNode ) {

              elem.parentNode.removeChild( elem );

     }

}

 
3.      哦,明白了

通过上面的分析,我们清楚的看到jQuery.html函数会首先把其中的script检索出来,然后对于每个script标签应用evalScript函数。
在这个函数中,对于外部JavaScript个内联JavaScript,进行了不同的处理。
1)     jQuery.html如何处理字符串中的外部script标签

jQuery.ajax({

     url: elem.src,

     async: false,

     dataType: "script"

});         

 
对于外部script标签,比如:,jQuery采用了同步Ajax方案(async: false)。这也是在各种不同浏览器中能够保证动态JS的加载顺序的关键所在。
2)     jQuery.html如何处理字符串中的内联script标签

jQuery.globalEval( elem.text || elem.textContent || elem.innerHTML || "" );

 
来看下globalEval函数的定义:

 
由此可见,对于内联的script标签,jQuery通过在head中创建script标签来执行。
 
4.      后记

目前来看,一切来龙去脉似乎清晰可见。那么大家有没有考虑过,如果动态加载加载不同域名下(Cross-Domain)的JavaScript文件,jQuery还能确保在所有浏览器下的JavaScript的执行顺序吗?
 
也就是说在当前流行的静态资源的CDN加速情况下,jQuery.html是不是一个完全之策呢?
请看下篇 如何确保JavaScript的执行顺序 - 之jQuery.html并非万能钥匙。待续。。。

 
 

来源:程序园用户自行投稿发布,如果侵权,请联系站长删除
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
您需要登录后才可以回帖 登录 | 立即注册