性能優化之無阻塞載入腳步方法比較

来源:http://www.cnblogs.com/LuckyWinty/archive/2016/11/05/6034077.html
-Advertisement-
Play Games

秋招結束了~~,好像偷懶了很久,沒更博了。總結一下自己近來看書的內容。 說明一下,內容大部分來自《高性能網站建設進階指南》。 亂入內容 Web應用和傳統桌面應用有一個共同的目標:儘可能快地響應用戶輸入。 怎樣才算是快?Jakob Nielsen是Web可用性領域知名且備受推崇的專家,引用他的觀點來說 ...


    秋招結束了~~,好像偷懶了很久,沒更博了。總結一下自己近來看書的內容。

說明一下,內容大部分來自《高性能網站建設進階指南》。

亂入內容

Web應用和傳統桌面應用有一個共同的目標:儘可能快地響應用戶輸入。   怎樣才算是快?Jakob Nielsen是Web可用性領域知名且備受推崇的專家,引用他的觀點來說就是:如果JavaScript代碼執行時間超過了0.1秒,頁面將會給人不夠平滑快捷的感覺,如果執行時間超過了1秒,則會感到應用程式緩慢,超過了10秒,那麼用戶將會非常沮喪。   性能分析器:Firebug性能分析器 當延遲變得很嚴重時:線程處理Web Workers、Gears   無阻塞載入腳步      script標簽的阻塞行為會對頁面性能產生負面影響。大多數瀏覽器在下載或執行腳本的同時不會下載其他內容。有時候這種阻塞是非必要的。所以,有些情況我們希望以不阻塞其他內容下載的方式來載入JavaScript。可以做到這點使頁面載入更快的有: 1.XHR Eval 2.XHR註入 3.Script in Iframe 4.Script DOM Element 5.Script Defer 6.document.write Script Tag   ①XHR Eval 比較好理解,就是為了並行載入更多的腳本,把一些腳本拆分,然後通過ajax的方式請求腳本,再通過eval來執行。 實例代碼:
   var xhrObj=getXHRObject();
   xhrObj.onreadystatechange=function(){
      if(xhrObj.readyState==4&&200==xhrObj.status){
         eval(xhrObj.responseText);
      }
  };
xhrObj.open('GET','A.js',true);
xhrObj.send(' ');

//獲取XHR對象的基本方法
function getXHRObject (){
   if (typeof XMLHttpRequest != "undefined"){
          return new XMLHttpRequest();
   } else if (typeof ActiveXObject != "undefined"){
 if (typeof arguments.callee.activeXString != "string"){
     var versions = [ "MSXML2.XMLHttp.6.0", "MSXML2.XMLHttp.3.0",
          "MSXML2.XMLHttp"],
          i, len;
     for (i=0,len=versions.length; i < len; i++){
     try {
        new ActiveXObject(versions[i]);
        arguments.callee.activeXString = versions[i];
        break;
     } catch (ex){
       //跳過
     }
    }
  }
   return new ActiveXObject(arguments.callee.activeXString);
  } else {
      throw new Error("No XHR object available.");
  }
}

缺點:

  通過XMLHttpRequest獲取的腳本必須部署在和主頁面相同的域中。

②XHR註入

    類似於XHR Eval,XHR註入技術也是通過XMLHttpRequest來獲取JavaScript的,但與eval不同的是,該機制通過創建一個script的DOM元素,然後把XMLHttpRequest的響應註入script中來執行JavaScript的,某些情況下使用這種機制的性能會優於eval。

示例代碼:

   var xhrObj=getXHRObject();
   xhrObj.onreadystatechange=function(){
      if(xhrObj.readyState==4){
         var scriptElem=document.createElement('script');
         document.getElementsByTagName('head')[0].appendChild(scriptElem);
         scriptElem.text=xhrObj.responseText;
      }
  };
xhrObj.open('GET','A.js',true);
xhrObj.send(' ');

③Script in Iframe

   主頁中的iframe和其他組件是並行載入的,與用iframe在一個HTML頁面中包含另一個頁面的傳統做法不同,Script in Iframe技術利用iframe無阻塞載入JavaScript,實現過程完全在HTML中完成。 示例代碼:
<iframe src='A.html' width=0 height=0 frameborder=0 id='frame1'></ifame>

缺點:

該技術使用了A.html,而不是A.js,因為iframe認為其返回的是HTML文檔。所有我們要做的就是在HTML文檔中把外部腳本轉換為行內腳本。並且要求iframe和主頁面同域。

附訪問iframe的方法:

1.通過frames數組:window.frames[0] 2.通過document.getElementById訪問。   ④Script DOM Element    利用script標簽,動態創建腳本,創建script元素,並設置其src值。 示例代碼:
var scriptElem=document.createElement('script');
scriptElem,src='http://test.js';
document.getElementByTagName('head')[0].appendChild(scriptElem);
⑤Script Defer   非常簡單,這個屬性的用途是表明腳本在執行時不會影響頁面的構造。也就是說,腳本會被延遲到整個頁面都解析完畢後再運行。因此,在<script>元素中設置defer屬性,相當於告訴瀏覽器立即下載,但延遲執行。

HTML5規範要求腳本按照它們出現的先後順序執行,因此第一個延遲腳本會先於第二個延遲腳本執行,而這兩個腳本會先於DOMContentLoaded事件執行。在現實當中,延遲腳本並不一定會按照順序執行,也不一定會在DOMContentLoad時間觸發前執行,因此最好只包含一個延遲腳本。

示例代碼:
<script defer src='A.js'></script>
  在這裡順便辨析一下defer屬性和async屬性

defer屬性:IE4.0就出現。defer屬聲明腳本中將不會有document.write和dom修改。瀏覽器會並行下載其他有defer屬性的script。而不會阻塞頁面後續處理。註:所有的defer腳本必須保證按順序執行的。

    <script type="text/javascript" defer></script>

async屬性:HTML5新屬性。腳本將在下載後儘快執行,作用同defer,但是不能保證腳本按順序執行。他們將在onload事件之前完成。

    <script type="text/javascript" defer></script>

Firefox 3.6、Opera 10.5、IE 9和最新的Chrome和Safari都支持async屬性。可以同時使用async和defer,這樣IE 4之後的所有IE都支持非同步載入。

沒有async屬性,script將立即獲取(下載)並執行,期間阻塞了瀏覽器的後續處理。如果有async屬性,那麼script將被非同步下載並執行,同時瀏覽器繼續後續的處理。

 

更多參考:https://segmentfault.com/a/1190000006778717

⑥document.write Script Tag   使用document.write把HTML標簽script寫入頁面中。  

技術綜述

不同情況下的最佳腳本載入技術的決策樹

決策樹中的六種結果詳解

 

 

本總結供自己查閱之用,不喜勿噴。。。 

 
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • nginx在工作中已經有好幾個環境在使用了,每次都是重新去網上扒博客,各種編譯配置,今天自己也整理一份安裝文檔和nginx.conf配置選項的說明,留作以後參考。像負載均衡配置(包括健康檢查)、緩存(包括清空緩存)配置實例,請參考http://seanlook.com/2015/05/17/ngin ...
  • A集成代碼生成器 [正反雙向(單表、主表、明細表、樹形表,開發利器)+快速構建表單 下載地址 ; freemaker模版技術 ,0個代碼不用寫,生成完整的一個模塊,帶頁面、建表sql腳本,處理類,service等完整模塊B 集成阿裡巴巴資料庫連接池druid; 資料庫連接池 阿裡巴巴的 druid。 ...
  • 邏輯層職責: 負責整個系統 中業務邏輯的處理。 邏輯層架構特點: 邏輯層業務複雜; 設計方式: 1、All In ONE方式:所有業務一個整體、一個文件、一個類里。 特點:簡單,適合業務量小; 問題:耦合性嚴重;文件內容複雜、開發維護代價高、牽一發動全身; 適合場景:創業期、業務不複雜; 2、業務垂... ...
  • 1.1概述 將一個複雜對象的構建與它的表示分離,使同樣的構建過程可以創建不同的表示。這就是生產器模式的定義。 如果一個類中有若幹個成員變數是其他類聲明的對象,那麼該類創建的對象就可以包含若幹個其他對象作為其成員。習慣上把一個對象中的成員對象稱作它的組件,例如,幾何(Geometry)類含有三角形(T ...
  • 1.許可權的簡單描述 2.實例表結構及內容及POJO 3.Shiro-pom.xml 4.Shiro-web.xml 5.Shiro-MyShiro-許可權認證,登錄認證層 6.Shiro-applicationContext-shiro.xml 7.HomeController三個JSP文件 1.許可權 ...
  • 一、前言 1.1、國際化簡介 國際化是指應用程式在運行的時候,根據客戶端請求來自的國家地區、語言的不同而顯示不同的界面(簡單說就是根據你的地區顯示相關地區的語言,如果你現在在英國,那麼顯示的語言就是英語),國際化的存在價值就是:當一個應用需要在全球使用。 國際化(Internationalizati ...
  • 1.1概述 提供一個創建一系列或相互依賴對象的介面,而無須指定他們具體的類。這就是抽象工廠模式的定義。 設計某些系統時可能需要為用戶提供一系列相關的對象,但系統不希望用戶直接使用new運算符實例化這些對象,而是應當由系統來控制這些對象的創建,否則用戶不僅要清楚地知道使用哪些類來創建這些對象,而且還必 ...
  • 一、前言 OGNL和標簽庫的作用,粗暴一點說,就是減少在JSP頁面中出現java代碼,利於維護。 1.1、OGNL 1.1.1、什麼是OGNL? OGNL(Object-Graph Navigation Language):對象圖形導航語言,是一種功能強大的表達式語言,通過簡單的語法,就能夠任意存取 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...