OneAPM大講堂 | 提高JavaScript性能的30個技巧

来源:https://www.cnblogs.com/oneapm/archive/2018/01/17/8306646.html
-Advertisement-
Play Games

文章系國內領先的 ITOM 管理平臺供應商 OneAPM 編譯呈現。 您是網站管理員還是網頁開發人員?想創建超快速的網站嗎? 今天我們來看看 JavaScript,這項神奇而又複雜的技術。它使網站內容更加豐富,但常常出現的運行性能問題又降低了用戶的體驗。事實已經證明,最佳的終端用戶體驗能提升網站的轉 ...


文章系國內領先的 ITOM 管理平臺供應商 OneAPM 編譯呈現。

您是網站管理員還是網頁開發人員?想創建超快速的網站嗎?

今天我們來看看 JavaScript,這項神奇而又複雜的技術。它使網站內容更加豐富,但常常出現的運行性能問題又降低了用戶的體驗。事實已經證明,最佳的終端用戶體驗能提升網站的轉換率、Google搜索排名以及訪問者的滿意度。高性能的JavaScript意味著會給您和您的公司帶來更多更好的業務。

下麵我們介紹提高 JavaScript 性能的一些技巧。同樣地,這或許可以幫助網站管理員和網站開發人員創建快速的網站,並提供一流的用戶體驗。

技巧 #1 – 評估局部變數

(http://blogs.msdn.com/b/ie/archive/2006/08/28/728654.aspx)

主要針對IE而言,由於局部變數的查找是從最特定作用域到最大作用域,且可以通過多個域層級,所以這種查找會導致查詢到通用的結果。在定義函數作用域的時候,如果一個局部變數在之前沒有進行過var變數聲明, 那麼此處一定要在變數名前加上var關鍵字以定義其當前的作用域和防止查詢,從而提高代碼的速度。

技巧 #2 – 創建代碼快捷方式以加速編碼

對於使用頻繁的有用代碼,可以通過為較長的代碼創建快捷方式來加快編碼過程,例如 document.getElementById。 通過創建一個快捷方式,編寫較長的腳本便不會耗時太久,並且可以節省整個過程的時間。

技巧 #3 – 在將元素片段添加到DOM之前對其實施操作

(http://www.jquery4u.com/dom-modification/improve-javascript-performance)

在創建 DOM 的元素節點之前,請確保已經執行了所有的操作,以提高 JavaScript 的性能。 這樣就無需再摒棄 Prepend和 Append 的 jQuery APIs 了。

技巧 #4 – 使用Minification保存位元組

(http://sixrevisions.com/web-development/10-ways-to-improve-your-web-page-performance)

通過刪除字元(標簽,源代碼文檔,空格等)而不改變文件功能的方式減小 JavaScript 文檔。

有許多縮小工具可以用來完成這個過程,並且還可以將縮小複原。 縮小是從源代碼中刪除所有不必要的字元而不改變其功能的過程。

技巧 #5 – 除非必要,否則不要使用嵌套迴圈

減少不必要的迴圈,例如 for 和 while 迴圈,以保持 JavaScript 的線性,並避免需要遍曆數千個對象。無用的迴圈可能會導致瀏覽器處理代碼時更困難,從而減緩速度。

技巧 #6 – 緩存對象以提高性能

很多時候,會重覆使用腳本來訪問某個對象。 將重覆訪問的對象存儲在用戶定義的變數中,並且之後在引用該對象時使用此變數,可以立刻實現性能提升。

技巧 #7 – 使用.js文件來緩存腳本

(http://www.javascriptkit.com/javatutors/efficientjs.shtml)

使用這種技術可以實現性能提升,因為它允許瀏覽器只載入腳本一次,當頁面被重新載入或重新訪問時只需要從緩存中調用腳本即可。

技巧 #8 – 將JavaScript放置到頁面的底部

將腳本儘可能放在頁面底部的位置會加快渲染進度,同時也會增加下載並行度。 其結果是頁面看起來載入得更快了,並且在某些情況下,它也可以減少所需要的總的代碼量。

技巧 #9 – 使用jQuery作為框架

jQuery 用於 HTML 腳本編程,是一個易於使用的 JavaScript 庫,可以幫助任何網站實現加速。 jQuery 提供了大量可以快速使用的插件,即使是新手程式員也不成問題。

技巧 #10 – 使用Gzip壓縮文件

(http://devmoose.com/coding/10-ways-to-instantly-speed-up-your-website)

使用 GZip 可以明顯地降低 JavaScript 文件的大小,節省帶寬,並加快響應時間。 有時 JavaScript 文件非常大,如果沒有經過壓縮,它可能會造成網站癱瘓。較小的文件能提供更快、更令人滿意的網頁體驗。

技巧 #11 – 不要使用With關鍵字

(http://blogs.msdn.com/b/ie/archive/2006/08/28/728654.aspx)

“With”這個關鍵詞被認為是害群之馬,因為它本身存在一些讓人倍感沮喪的缺陷。雖然有了它使用局部屬性的過程會變得更加簡單,但當在其他作用域中查找變數時,使用With會增大代價。

技巧 #12 – 儘量減少對HTTP的請求

(http://www.websiteoptimization.com/speed/tweak/http)

通過結合外部文件和直接在 XHTML 頁面中嵌入 JavaScript 來儘量減少對 HTTP 返回頁面的請求。 每一個特定的 HTTP 請求傳輸至伺服器端都會導致大量的時延。

技巧 #13 – 實現事件代理

使用事件代理將會使利用單個事件處理程式來為整個頁面管理某種事件類型變得更加容易。 如果不使用事件代理,大型的 Web 應用程式可能會由於過多的事件處理程式而停止工作。 實現事件代理的好處包括: 需要管理的功能更少,代碼和 DOM 之間的聯繫更少,進程所需的記憶體更少。

技巧 #14 – 不要重覆使用相同的腳本

(http://www.abhishekbharadwaj.com/2010/12/speed-up-your-website-avoid-duplicate-scripts)

重覆的腳本對性能會造成顯著的影響。重覆的腳本會創建不需要的HTTP請求,尤其是在IE瀏覽器中。在HTML頁面中使用腳本標簽,可以幫助避免意外地生成重覆的腳本。

技巧 #15 – 移除雙美元符號$$

(http://www.mellowmorning.com/2008/05/18/javascript-optimization-high-performance-js-apps)

當考慮提升網站的速度時,使用雙美元符號$$並不是必要的選擇。

技巧 #16 – 創建變數引用

(http://mondaybynoon.com/2009/04/27/a-couple-of-quick-tips-for-javascript-optimization)

當需要重覆使用某個節點時,最好為該節點定義一個變數,使用節點時對變數進行引用,而不是反覆來回操作。針對少量這樣的節點,也許這並不能顯著地提升性能,但是在節點數量很大時,這種方法就可以帶來明顯的影響。

技巧 #17 – 提高Object Detection的速度

(http://dean.edwards.name/weblog/2005/12/js-tip1)

一種更有效的使用 Object Detection 的方法是使用基於對象檢測而動態創建的代碼,而不是在函數內部去執行對象檢測。

技巧 #18 – 編寫有效的迴圈

(http://robertnyman.com/2008/04/11/javascript-loop-performance)

根據瀏覽器的不同,不同的迴圈實現方法也會對網站的性能產生很大的影響。 編寫不正確的迴圈可能會降低那些具有大訪問量的頁面的響應速度,或者導致同時運行多個迴圈。

技巧 #19 – 縮短作用域鏈

全局作用域通常較慢,因為每次執行函數的時候,它會引發創建一個臨時的調用作用域,JavaScript 會在作用域鏈中搜索第一個對象,如果找不到該變數,則會遍歷鏈直到搜索到全局對象。

技巧 #20 – 對NodeLists直接索引

NodeLists 是動態的,會占用大量的記憶體,因為當底層的文檔對象更改時它們也會被更新。 直接對列表進行索引會速度更快,因為此時瀏覽器不需要創建節點列表對象。

技巧 #21 – 不要使用‘eval’

雖然“eval”函數是運行任何代碼的好方法,但是在實際運行時,傳遞給 eval 函數的每個字元串都需要進行解析和執行。 每次調用eval函數的時候,都會引入這些時間開銷。

技巧 #22 – 使用函數內聯

(https://dl.acm.org/citation.cfm?id=844097)

函數內聯有助於減少函數調用的成本,並用被調用的函數體替換函數調用。 在 JavaScript 中執行函數調用是一個高成本的操作,因為需要執行幾個準備步驟:為參數分配空間,複製參數以及解析函數名稱。

技巧 #23 – 實現 Common Sub-expression Elimination (CSE)

(http://sunilkumarn.wordpress.com/2010/10/19/common-subexpression-elimination-cse)

Common Sub-expression Elimination (CSE)是一種以性能為目標的編譯器優化技術,用於搜索相同的表達式對象,並用保存著計算值的單個變數替換它們。可以認為,對通用子表達式使用單個的局部變數總是比保持代碼不變具有更快的速度。

技巧 #24 – 離線構建DOM節點以及所有子節點

當向站點添加複雜的內容(例如表格)時,通過離線的方式添加複雜的子樹可以提升性能。

技巧 #25 – 儘量不要使用全局變數

由於腳本引擎需要搜索作用域,所以當從函數內部或其他作用域內引用全局變數時,如果局部作用域丟失,全局變數將被銷毀。如果全局作用域中的變數並不一直存在於腳本的生命周期,則可以提升性能。

技巧 #26 – 使用原始的函數操作而不使用函數調用

通過使用等效的原函數而非函數調用,可以在對性能有關鍵影響的迴圈和函數中實現速度提升。

技巧 #27 – 不要一直保留對其他文檔的引用

(http://dev.opera.com/articles/view/efficient-javascript/?page=4#docreferences)

當腳本結束後不再保留對其他文檔的引用可以實現更快的性能。因為對其他文檔中的對象進行的任何引用不會被保存在整個 DOM 樹中,並且腳本環境也不會一直保留在記憶體中。 因此文檔本身不用再被載入。

技巧 #28 – 使用XMLHttpRequest

(http://dev.opera.com/articles/view/efficient-javascript/?page=4#docreferences)

XMLHttpRequest 有助於減少來自伺服器端的內容數量,並且避免在頁面載入的間隙銷毀和重新創建腳本環境對性能造成的影響。一定要確保支持 XMLHttpRequest,否則可能會導致問題和混淆。

技巧 #29 – 避免使用try-catch-finally結構

(http://dev.opera.com/articles/view/efficient-javascript/?page=2)

每當執行 catch 子句時,捕獲的異常對象被分配給一個變數,“try-catch-finally”會在運行時在當前作用域中創建一個新變數。 許多瀏覽器不能有效地處理這個過程,因為變數是在運行時被創建和銷毀的。避免使用它!

技巧 #30 – 不要誤用 for-in

(http://dev.opera.com/articles/view/efficient-javascript/?page=2)

由於“for-in”迴圈需要腳本引擎構建包含所有可枚舉屬性的列表,因此 for 迴圈內的代碼是不會修改這個列表的。 在 for 迴圈內部,預先計算出列表的長度並賦給變數 len,然後進行迭代。

後續我們還會發佈有關性能管理的系列帖子...敬請關註!

Browser Insight 是一個基於真實用戶的 Web 前端性能監控平臺,能夠幫大家定位網站性能瓶頸,網站加速效果可視化;支持瀏覽器、微信、App 瀏覽 HTML 和 HTML5 頁面。想閱讀更多技術文章,請訪問 OneAPM 官方技術博客

來源:http://blog.oneapm.com/apm-tech/802.html


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

-Advertisement-
Play Games
更多相關文章
  • 【轉】Android總結篇系列:Activity生命周期 Android官方文檔和其他不少資料都對Activity生命周期進行了詳細介紹,在結合資料和項目開發過程中遇到的問題,本文將對Activity生命周期進行一次總結。 Activity是由Activity棧進管理,當來到一個新的Activity ...
  • 尊重勞動成果,轉載請標明出處:http://www.cnblogs.com/tangZH/p/8305063.html 我們在自定義view的時候有時候需要給組件一個背景,而這個背景可能是不規則的,比如一個紅色背景,但是左邊有圓角,右邊沒有,那麼應該怎麼做呢?在這裡我以textView為例。 用xm ...
  • 1、讀取通信錄 1)、9.0以前 2)、9.0以後 2、調用通信錄UI 1)、9.0以前 2)、9.0以後 3、參考 0、寫在前面 plist 需要設置隱私許可權 Privacy - Contacts Usage Description : 請求訪問通訊錄(自定義) 1、讀取通信錄 1)、9.0以前 ...
  • 首先必須使用釘釘開發版,並確保已經通過此鏈接打開了調試功能: https://open-doc.dingtalk.com/docs/doc.htm?spm=5176.10694750.0.0.3tPHed&treeId=171&articleId=104908&docType=1 如果出現點擊Ins ...
  • 小程式的二維碼,是靜態的,在公眾號里傳播的時候,效果不太好,但是因為小程式的logo 很大,可以容納很多的內容,所以就希望中間的部分可以動態顯示。 經過我們的驗證,是可行的,來幾張效果圖 1. 二次元小程式碼,將一些搞小的gif動畫放在小程式碼里,非常適合在二次元的世界里傳播 2. 游戲小程式碼 , ...
  • 1.首先進入蘋果官網 找到support https://support.apple.com 2.找到查詢ipad型號的地方 點擊Check coverage for your product 3.輸入你的ipad序列號,序列號在ipad上 通用 >關於本機 >序列號 ...
  • 一,Jenkins http://jenkins-ci.org 二,iOS單元測試的持續集成 在Xcode進入OCUnit作為單元測試框架前,把單元測試分為兩種:Logic Test和Application Test.Logic Test負責測試邏輯部分,一般邏輯部分是沒有UI的。 Applicat ...
  • 字元串方法字元串切割slicestrObj.slice(start[,end])參數為負,將它作為length+end處理,此處length為字元串的長度。 str.slice( 2)可以取字元串後兩位substringstrObj.substring(start[,end])  ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...