欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

讓瀏覽器非阻塞加載javascript的幾種方法小結(jié)

 更新時間:2011年04月25日 01:26:30   作者:  
通常大多數(shù)瀏覽器是并行下載資源的,但由于外部腳本的特殊性例如通過腳本改變文檔的DOM結(jié)構(gòu)、腳本之間的存在依賴關(guān)系、使用document.write 向頁面輸出HTML等。
瀏覽器為了確保正確執(zhí)行腳本和呈現(xiàn)布局在瀏覽器加載和執(zhí)行完成它之前會完全阻塞頁面后續(xù)內(nèi)容的呈現(xiàn)和其他資源的加載。

    在頁面的加載過程中如果可以做到內(nèi)容的逐步呈現(xiàn),對于良好的用戶體驗來說是非常重要的。通常我們也會在wondow對象的onload事件處理函數(shù)中做一些事情,但由于腳本阻塞加載和呈現(xiàn)的特性這一方面增加了頁面載入時間推遲了onload事件的觸發(fā),另一方面也延遲了用戶所期待的反饋。這就需要我們使用一些方法來讓瀏覽器以非阻塞的方式加載外部腳本。

一  使用XMLHttpRequest對象異步方式加載外部腳本。

    這種方式好處是觸發(fā)較少的瀏覽器忙指示器,能夠被所有現(xiàn)代瀏覽器的所支持。不足的之處在于由于瀏覽器的跨域安全機制所以只能允許加載同域下外部腳本。另外如果多個腳本之間存在依賴關(guān)系的話,需要使用編寫相關(guān)的隊列管理腳本來控制多個腳本的執(zhí)行順序。

二  使用Javascript來動態(tài)創(chuàng)建外部腳本的SCRIPT元素

   這種方式是我認(rèn)為跨域并行加載外部腳本情況下的最佳方案,實現(xiàn)方法是使用Javascript來動態(tài)的創(chuàng)建在HTML中引用外部腳本所需要srcript元素并給創(chuàng)建的srcript元素的src屬性設(shè)置相應(yīng)的外部腳本的URL來實現(xiàn)和其他資源并行加載。

四  使用iframe加載外部腳本

    這種方式我們需要使用一個新HTML頁面把外部腳本轉(zhuǎn)換成到該HTML頁面的行內(nèi)腳本,然后在主頁面中使用iframe加載這個包含腳本的HTML頁面,使用這種方式需要重構(gòu)部分代碼來訪問主頁面中DOM元素。而且IFRAM是開銷相對較大DOM元素,同樣也有跨域限制。

五 使用Script標(biāo)簽的 derfer 屬性

    這種方式是實現(xiàn)非阻塞并行加載外部腳本的最簡單的方式,只需要在引用外部腳本的是常規(guī)方式上給SCRIPT標(biāo)簽應(yīng)用defer屬性即可。但是使用這種方式加載外部腳本缺點是它只在部門瀏覽器中實現(xiàn)并行加載因此兼容性欠缺。

六 docuument.write script tag

    這種方式實現(xiàn)起來也比較簡單,就是直接使用是javascript的document.write方法來輸出在HTML中引用外部腳本的script標(biāo)記的字符串。不足之處和方法五一樣兼容性欠缺。

總結(jié)

   上述幾種方式需要根據(jù)具體需求,如是否需要跨域?是否需要確保腳本按順序執(zhí)行?是否需要觸發(fā)更多或更少的瀏覽器的忙指示器?以及兼容性,支持的代碼量來確定來綜合考慮那種方式才是追合適的。

相關(guān)文章

  • JavaScript計算值然后把值嵌入到html中的實現(xiàn)方法

    JavaScript計算值然后把值嵌入到html中的實現(xiàn)方法

    下面小編就為大家?guī)硪黄狫avaScript計算值然后把值嵌入到html中的實現(xiàn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-10-10
  • 深入淺析JavaScript中的作用域和上下文

    深入淺析JavaScript中的作用域和上下文

    javascript中的作用域(scope)和上下文(context)是這門語言的獨到之處,這部分歸功于他們帶來的靈活性。本文給大家介紹JavaScript中的作用域和上下文,感興趣的朋友一起學(xué)習(xí)
    2016-03-03
  • js實現(xiàn)數(shù)字從零慢慢增加到指定數(shù)字示例

    js實現(xiàn)數(shù)字從零慢慢增加到指定數(shù)字示例

    今天小編就為大家分享一篇js實現(xiàn)數(shù)字從零慢慢增加到指定數(shù)字示例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • 讓瀏覽器崩潰的12行JS代碼(DoS攻擊分析及防御)

    讓瀏覽器崩潰的12行JS代碼(DoS攻擊分析及防御)

    現(xiàn)在有一段12行的JavaScript代碼,可以讓firefox、chrome、safari瀏覽器崩潰,而且還能讓iphone重啟、安卓閃退,本文作者對于該12行代碼進行了分析解讀并且提出了相應(yīng)的防御辦法,歡迎大家一同探討。有需要的朋友們可以參考借鑒。
    2016-10-10
  • 微信小程序通過點擊事件傳參(data-)的操作示例

    微信小程序通過點擊事件傳參(data-)的操作示例

    微信小程序可以通過直接寫 data-index="1" 進行數(shù)據(jù)的綁定 ,利用 bindtap 點擊事件執(zhí)行函數(shù)從而獲取到參數(shù)信息,本文給大家介紹微信小程序通過點擊事件傳參(data-)的操作,感興趣的朋友一起看看吧
    2023-12-12
  • js-FCC算法-No repeats please字符串的全排列(詳解)

    js-FCC算法-No repeats please字符串的全排列(詳解)

    下面小編就為大家?guī)硪黄猨s-FCC算法-No repeats please字符串的全排列(詳解)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-05-05
  • 微信小程序?qū)崿F(xiàn)slideUp、slideDown滑動效果及點擊空白隱藏功能示例

    微信小程序?qū)崿F(xiàn)slideUp、slideDown滑動效果及點擊空白隱藏功能示例

    這篇文章主要介紹了微信小程序?qū)崿F(xiàn)slideUp、slideDown滑動效果及點擊空白隱藏功能,涉及微信小程序事件響應(yīng)、頁面元素屬性動態(tài)操作實現(xiàn)滑動與蒙層功能相關(guān)技巧與注意事項,需要的朋友可以參考下
    2018-12-12
  • 解決uniapp上傳小程序體積過大的問題

    解決uniapp上傳小程序體積過大的問題

    在昨天的工作中遇到了一個微信小程序上傳代碼過大的情況,在這里總結(jié)一下具體的解決步驟,首先介紹一下,技術(shù)棧是使用uniapp框架+HBuilderX的開發(fā)環(huán)境,需要的朋友可以參考下
    2023-09-09
  • JavaScript進階練習(xí)及簡單實例分析

    JavaScript進階練習(xí)及簡單實例分析

    下面小編就為大家?guī)硪黄狫avaScript進階練習(xí)及簡單實例分析。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-06-06
  • 微信小程序?qū)崿F(xiàn)導(dǎo)航功能的操作步驟

    微信小程序?qū)崿F(xiàn)導(dǎo)航功能的操作步驟

    這篇文章主要給大家介紹了關(guān)于微信小程序?qū)崿F(xiàn)導(dǎo)航功能的操作步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03

最新評論