如何確保JavaScript的執(zhí)行順序 之jQuery.html并非萬(wàn)能鑰匙
在上一篇文章《如何確保JavaScript的執(zhí)行順序 - 之jQuery.html深度分析》中,我們揭示了jQuery.html函數(shù)之所以能在各種瀏覽器下保持動(dòng)態(tài)JS順序執(zhí)行,其秘密在于 – 同步AJAX獲取外部JavaScript。
我們先來簡(jiǎn)單回顧下HTML源代碼(test2.htm):
<html>
<head>
<title></title>
<script src="js/jquery-1.4.4.js" type="text/javascript"></script>
<script>
$(function(){
$('#container').html('<script src="./service.ashx?file=js/jquery-ui.js&delay=2000" type="text\/javascript"><\/script>' + '<script>alert(typeof(jQuery.ui));<\/script>');
});
</script>
</head>
<body>
<div id="container">
</div>
</body>
</html>
順便一提的是,通過這種方式加載的外部JavaScript不可以在Firebug中調(diào)試,因?yàn)锳JAX結(jié)束后外部JavaScript的解析和內(nèi)聯(lián)JavaScript的解析是一樣的(都是調(diào)用jQuery.globalEval):
下面進(jìn)入本篇文章的主題:如果加載的JS是在其它域下面的,jQuery.html還能在各個(gè)瀏覽器下都能保證JS的順序執(zhí)行么?
2. 建立測(cè)試案例
1) 準(zhǔn)備兩個(gè)域名
為了測(cè)試,我在個(gè)人主頁(yè)(http://sanshi.me/)下面臨時(shí)創(chuàng)建了兩個(gè)子域名,分別是:
http://test.sanshi.me/
http://test1.sanshi.me/
2) 更新Demo頁(yè)面(test2_1.htm)
我會(huì)把test2_1.htm放在第一個(gè)子域名下,訪問地址為http://test.sanshi.me/jsorder/test2_1.htm,其源代碼如下:
<html>
<head>
<title></title>
<script src="js/jquery-1.4.4.js" type="text/javascript"></script>
<script>
$(function () {
$('#container').html('<script src="http://test1.sanshi.me/jsorder/service.ashx?file=js/jquery-ui.js&delay=2000" type="text\/javascript"><\/script>' + '<script>alert(typeof(jQuery.ui));<\/script>');
});
</script>
</head>
<body>
<div id="container">
</div>
</body>
</html>
可以看到,其中的jQueryUI腳本指向的是第二個(gè)域名下的(test1.sanshi.me)。
3) 在不同瀏覽器下測(cè)試
test2_1.htm 使用jQuery.html函數(shù)動(dòng)態(tài)加載其它域下的JavaScript | |
Firefox 3.6 |
|
IE 8 |
|
Chrome 10 |
|
Safari 4 |
|
Opera 11 |
|
3. jQuery.html并非萬(wàn)能鑰匙,那么
不知道大家是否還記得我們?cè)诘谝黄恼轮刑岬降膖est3.htm不,這個(gè)結(jié)果和那個(gè)示例的結(jié)果一模一樣,jQuery.html也并非萬(wàn)能鑰匙。這不禁讓我們懷疑這兩個(gè)示例的內(nèi)部邏輯是否一樣?
但是第二篇文章不是明明白白告訴我們,jQuery.html使用的是同步AJAX的機(jī)制來加載外部JS的么?等等。。。。。。
大家有沒有從上面的分析中發(fā)現(xiàn)問題,AJAX來加載其他域的資源,這不是明擺著違背了大名鼎鼎的同源策略(Same Origin Policy)了么?所以jQuery不可能這么實(shí)現(xiàn),我們來看看jQuery.ajax文檔是怎么說的:
看來我們?cè)诘诙恼轮锌吹降倪@個(gè)函數(shù)(evalScript)內(nèi)部并非真的通過同步AJAX來獲取數(shù)據(jù):
4. 深入jQuery.ajax函數(shù),看看怎么加載不同域下的JS文件
注釋已經(jīng)寫的很清楚了,如果是通過GET方式請(qǐng)求JavaScript文件,并且這個(gè)文件是在其他域下面的(remote),那么就通過在head中添加script標(biāo)簽來處理,而不是走AJAX的流程。所以在這個(gè)條件分支結(jié)束的時(shí)候,直接從函數(shù)體返回:
經(jīng)過分析,我們發(fā)現(xiàn)在動(dòng)態(tài)加載不同域的JavaScript時(shí),jQuery.html其實(shí)采用了在head中添加script標(biāo)簽的做法(不管是外部JS或者內(nèi)聯(lián)JS),這和我們?cè)诘谝黄恼轮刑岬降?/SPAN>test3.htm是一模一樣的邏輯,這也驗(yàn)證了我們的想法:
由此可見,如果想兼容CDN加速靜態(tài)資源的情況,還必須使用第一篇文章中提到的“方案一,如何在動(dòng)態(tài)添加script標(biāo)簽時(shí)確保執(zhí)行順序”。
5. 后記
本來這個(gè)系列的文章到這就應(yīng)該結(jié)束了。不過在我測(cè)試jQuery1.5.1后,居然發(fā)現(xiàn)和我用的jQuery1.4.4是有差異的,早就聽說jQuery1.5.1對(duì)AJAX部分進(jìn)行了重構(gòu),沒想到還真的對(duì)我們的代碼有點(diǎn)影響。
具體是哪方面的影響,請(qǐng)看下一篇文章:如何確保JavaScript的執(zhí)行順序 - 之jQuery1.5.1與jQuery1.4.4的細(xì)微差異。待續(xù)。。。
- JavaScript 全面解析各種瀏覽器網(wǎng)頁(yè)中的JS 執(zhí)行順序
- JavaScript 在各個(gè)瀏覽器中執(zhí)行的耐性
- Html中JS腳本執(zhí)行順序簡(jiǎn)單舉例說明
- javascript attachEvent綁定多個(gè)事件執(zhí)行順序問題
- 如何確保JavaScript的執(zhí)行順序 之jQuery.html深度分析
- 如何確保JavaScript的執(zhí)行順序 之實(shí)戰(zhàn)篇
- 解決火狐瀏覽器下JS setTimeout函數(shù)不兼容失效不執(zhí)行的方法
- Javascript代碼在頁(yè)面加載時(shí)的執(zhí)行順序介紹
- js 異步操作回調(diào)函數(shù)如何控制執(zhí)行順序
- javascript的解析執(zhí)行順序在各個(gè)瀏覽器中的不同
- js判斷瀏覽器類型為ie6時(shí)不執(zhí)行
- 探析瀏覽器執(zhí)行JavaScript腳本加載與代碼執(zhí)行順序
相關(guān)文章
使用jQuery操作Cookies的實(shí)現(xiàn)代碼
Cookies是一種能夠讓網(wǎng)站服務(wù)器把少量數(shù)據(jù)儲(chǔ)存到客戶端的硬盤或內(nèi)存,或是從客戶端的硬盤讀取數(shù)據(jù)的一種技術(shù)2011-10-10jQuery實(shí)現(xiàn)新消息閃爍標(biāo)題提示的方法
這篇文章主要介紹了jQuery實(shí)現(xiàn)新消息閃爍標(biāo)題提示的方法,實(shí)例分析了jQuery操作樣式的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-03-03用jquery中插件dialog實(shí)現(xiàn)彈框效果實(shí)例代碼
這篇文章介紹了jquery中插件dialog實(shí)現(xiàn)彈框效果實(shí)例代碼,有需要的朋友可以參考一下2013-11-11jQuery仿移動(dòng)端支付寶鍵盤的實(shí)現(xiàn)代碼
最近做項(xiàng)目時(shí)碰到一個(gè)需求,就是在移動(dòng)端支付頁(yè)面點(diǎn)擊支付按鈕彈出一個(gè)支付鍵盤,類似于支付寶的那種。項(xiàng)目只是單純的手機(jī)網(wǎng)站,所以這個(gè)功能由前端來實(shí)現(xiàn),下面小編給大家?guī)砹薺Query仿移動(dòng)端支付寶鍵盤的實(shí)現(xiàn)代碼,需要的朋友參考下吧2018-08-08jQuery實(shí)現(xiàn)圖片加載完成后改變圖片大小的方法
這篇文章主要介紹了jQuery實(shí)現(xiàn)圖片加載完成后改變圖片大小的方法,結(jié)合實(shí)例形式分析了jQuery圖片樣式與頁(yè)面元素屬性動(dòng)態(tài)操作的相關(guān)技巧,需要的朋友可以參考下2016-03-03