Script的加載方法小結(jié)
1.靜態(tài)加載
CSS,圖片資源文件在頁面渲染過程中可以并行下載,不會阻塞。在IE8,F(xiàn)F下,也可以支持JS的并行下載。盡管頁面的JS下載加速了,但是JS對頁面渲染的阻塞還是依然存在的,只有JS加載完畢了,頁面的剩余部分才能繼續(xù)渲染。放在Head部分的Script是最為惡劣的,因為對頁面來說,Head部分是require的,是后部分所必須的,Head部分不加載完畢,Body部分不會開始解析,Body解析之前,頁面是空白的。靜態(tài)Script放到頁面的哪部分來說都是阻塞,從瀏覽器實現(xiàn)的角度來說很好理解,因為JS代碼中完全有可能修改頁面元素影響Dom結(jié)構(gòu)。因為瀏覽器對JS行為的不可預知,所以只好等前面的Script加載完畢后再繼續(xù)渲染。所以最佳實踐往往是說將Script放到頁面底部</body>附近。
JS加載對前臺性能的影響,雅虎優(yōu)化原則之一是減少Http請求數(shù),壓縮JS,合并JS,減少JS數(shù)。
若是業(yè)務上有很多獨立模塊化的JS需要加載,可以考慮在線打包的方案。
2。延遲加載
W3C標準HTML4.01給Script標簽定義了一個defer屬性,指明該JS不會改變Dom的content,瀏覽器可繼續(xù)解析和渲染,無需阻塞在該Script。
http://www.w3.org/TR/1999/REC-html401-19991224/interact/scripts.html
但部分瀏覽器并不支持該屬性。所以它不是個很好的跨瀏覽器解決方案。
3.動態(tài)加載
<script type="text/javascript">
var js = document.createElement("script");
js.src = '**.js';
document.getElementsByTagName("head")[0].appendChild(js);
</script>
這段代碼創(chuàng)建了script標簽,并插入這條標簽到文檔中。關(guān)鍵在于,這個腳本的加載時異步的,不會影響頁面渲染的進程,不會阻塞頁面內(nèi)容的展示。這樣的方式盡管不會阻塞頁面資源的加載,但卻可能會阻塞其他的script腳本,不同瀏覽器在這點上的表現(xiàn)是有非常大的差異的,參看這篇文章動態(tài)引入的外部 JS 文件在各瀏覽器中的加載順序不一致
有兩點非常突出,
1.同樣的動態(tài)加載代碼,不同瀏覽器對動態(tài)加載進來的js,是否阻塞下條Script標簽的表現(xiàn)是不一樣的
2.實現(xiàn)動態(tài)加載的那段代碼順序不同,對同一個瀏覽器來說,結(jié)果可能是非常迥異的,
如:
代碼順序的調(diào)換,IE的表現(xiàn)就不一樣
所以,對動態(tài)加載腳本,需要重點關(guān)注的一個問題是,所動態(tài)加載的JS腳本的接口依賴問題。這個問題的解決方案也不復雜,既根據(jù)實現(xiàn)業(yè)務的需要跟蹤所加載腳本的加載狀態(tài)。加載狀態(tài)的判斷在IE下用readyState屬性,非IE瀏覽器支持,腳本加載完成后的onload方法的調(diào)用。
業(yè)界優(yōu)秀的延遲加載庫
Ryan Grove 的LazeLoad https://github.com/rgrove/lazyload
Kyle Simpson 的 LABjs http://labjs.com/
相關(guān)文章
基于JavaScript實現(xiàn)鼠標懸浮彈出跟隨鼠標移動的帶箭頭的信息層
這篇文章主要介紹了基于JavaScript實現(xiàn)鼠標懸浮彈出跟隨鼠標移動的帶箭頭的信息層 的相關(guān)資料,需要的朋友可以參考下2016-01-01BootStrap 下拉菜單點擊之后不會出現(xiàn)下拉菜單(下拉菜單不彈出)的解決方案
最近學到Bootstrap下拉菜單,學懂了教程內(nèi)容之后自己敲一個點擊按鈕底下彈出下拉菜單的小demo,寫完代碼發(fā)現(xiàn)運行之后點擊按鈕沒反應,下拉菜單彈不出來,下面給大家分享下解決方案2016-12-12淺談js在html中的加載執(zhí)行順序,多個jquery ready執(zhí)行順序
下面小編就為大家?guī)硪黄獪\談js在html中的加載執(zhí)行順序,多個jquery ready執(zhí)行順序。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-11-11