在上一篇文章《如何确保JavaScript的执行顺序 - 之实战篇》中我们发现jQuery的html函数能够确保动态加载的JavaScript按照引入顺序执行。我们先来简单回顾下HTML源代码test2.htmhtmlheadtitle/titlescript srcjs/jquery-1.4.4.js typetext/javascript/scriptscript$(function(){$(#container).html(script src./service.ashx?filejs/jquery-ui.jsdelay2000 typetext\/javascript\/script scriptalert(typeof(jQuery.ui));\/script);});/script/headbodydiv idcontainer/div/body/html2. 调试单步跟进逐行分析jQuery源代码是一件相当枯燥的事情。我这里会以test2.htm为目标调试进入jQuery源代码。1) 首先在html: 打一个断点刷新页面这里的value是字符串script src./service.ashx?filejs/jquery-ui.jsdelay2000 typetext/javascript/scriptscriptalert(typeof(jQuery.ui));/script我们来看会进入那个条件分支首先看看rnocache是啥可见value中含有 script 字符串不会进入第二个条件分支。2) 进入html函数的最后一个条件分支来看看append函数3) 进入domManip函数继续单步调试发现目标这里有对scripts的长度判断应该是已经分析了输入字符串并提取了其中的script标签我们来看下这里的局部变量scripts的内容4) 发现目标这里的两个局部变量scripts和evalScript是我们重点需要关注的我们分别来看下scripts这是一个数组包含两个script标签[script src​./​service.ashx?filejs/​jquery-ui.jsdelay2000 type​text/​javascript​/script​, script​alert(typeof(jQuery.ui));​/script​]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标签比如script src./service.ashx?filejs/jquery-ui.jsdelay2000 typetext/javascript/scriptjQuery采用了同步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的执行顺序吗