性能up!面向前端開發人員的14個JavaScript代碼優化技巧

2020-12-24 讀芯術

全文共4872字,預計學習時長13分鐘

圖源:unsplash

用戶訪問網站設備的硬體規格我們沒法控制,終端用戶訪問網站的設備或高端或低端,網際網路連接或好或差,這意味著我們必須儘可能優化網站,以滿足所有用戶的需求。而與此同時,據W3Tech統計,全世界將近96%的網站都在使用JavaScript,JavaScript已成為有史以來最熱門的程式語言之一。

以下是一些小貼士,以供你更好地優化JavaScript代碼,展現更好的性能。

順便一提,請確保共享和重用JS組件,以達成高質量代碼(需要時間來生成)和合理交付時間之間的恰當平衡。可以使用Bit (Github)之類的流行工具將項目中的組件(vanilla JS,TS,React,Vue等)共享到Bit的組件中心,這樣不會浪費太多時間。

1.刪除不用的代碼和功能

應用程式包含的代碼越多,需要傳輸到客戶端的數據就越多。瀏覽器解析代碼所需時間也越長,有時有些功能可能根本沒有用到。最好只在開發環境中保留這些額外的代碼,而不要將其用於生產環境,這樣就不會給客戶端的瀏覽器帶來無用代碼的負擔。

不斷詢問自己某個功能、特性或代碼是否必要。可以手動或使用Uglify或google’s closurecompiler等工具移除不用的代碼,甚至可以用一種名為搖樹優化(tree shaking)的技術,從應用程式中移除不用的代碼。

Webpack之類的打包器便提供這種技術,如果想刪除不用的npm包,可以使用npm prune命令。

圖源:unsplash

2.隨時緩存

緩存通過減少延遲和網絡流量來提高網站的速度和性能,從而縮短顯示資源所需的時間。這可以通過緩存應用程式接口(Cache API)或超文本傳輸協議緩存(HTTPcaching)來實現。在滿足特定條件(如發布新內容)時,上述緩存機制能夠處理和重新生成緩存。

3.避免內存洩漏

高級語言JS負責幾個底層管理,比如內存管理。垃圾回收機制在大多數程式語言中十分常見。通俗來說,垃圾回收機制就是簡單地收集和釋放已經分配給目標對象的內存,而這些內存並沒有在程序的任何部分使用。C語言之類的程式語言中,開發人員必須使用malloc()和dealloc()函數來分配和釋放內存。

儘管JavaScript自動執行垃圾回收,但有時它並不完美。JavaScript ES6中,映射(Map)和集合(Set)和它們的「較弱」的同胞一起引入。這種「較弱」的同類被稱為WeakMap和WeakSet,它們對對象的引用「較弱」,允許對未引用的值進行垃圾回收,從而防止內存洩漏。

4.儘早跳出循環

大周期循環必然會消耗大量寶貴時間,因此要儘早跳出循環。關鍵字break和continue可以做到這一點。編寫最高效的代碼是你的責任。在下面的例子中,如果沒有跳出(break)循環,代碼將運行循環1000000000次,這顯然導致了重載。

let arr = new Array(1000000000).fill('----');

arr[970] = 'found';

for (let i = 0; i < arr.length; i++) {

if (arr[i] === 'found') {

console.log("Found");

break;

}

}

在下面的例子中,若循環與條件不匹配時沒有使用繼續(continue)關鍵字,該函數將持續運行1000000000次。我們僅處理處於偶數位置的數組元素,這將循環執行減少了近一半。

let arr = new Array(1000000000).fill('----');

arr[970] = 'found';

for (let i = 0; i < arr.length; i++) {

if(i%2!=0){

continue;

};

process(arr[i]);

}

圖源:unsplash

5.最小化變量計算次數

可使用閉包減少變量的計算次數。通俗來說,JavaScript中的閉包可以從內部函數訪問外部函數。每次創建函數時都會創建閉包,而不是調用。即使外部函數已經返回,內部函數也可以訪問外部作用域的變量。

通過以下兩個實例來解釋這一點:

function findCustomerCity(name) {

const texasCustomers = ['John','Ludwig', 'Kate'];

const californiaCustomers = ['Wade','Lucie','Kylie'];

return texasCustomers.includes(name) ?'Texas' :

californiaCustomers.includes(name) ?'California' : 'Unknown';

};

多次調用上述函數,每次都會創建一個新對象。每次調用中,內存都被畫蛇添足地重新分配給變量texasCustometrs 和californiaCustomers。

使用帶有閉包的解決方案可僅實例化變量一次。看看下面的例子:

function findCustomerCity() {

const texasCustomers = ['John','Ludwig', 'Kate'];

const californiaCustomers = ['Wade','Lucie','Kylie'];

return name =>texasCustomers.includes(name) ? 'Texas' :

californiaCustomers.includes(name) ?'California' : 'Unknown';

};let cityOfCustomer = findCustomerCity();cityOfCustomer('John');//Texas

cityOfCustomer('Wade');//California

cityOfCustomer('Max');//Unknown

上例中,在閉包的輔助下,返回到變量cityOfCustomer的內部函數可以訪問外部函數findCustomerCity()的常量。每當內部函數被調用,其名稱作為參數傳遞,不需要再次實例化常數。

6.避免使用delete關鍵字

delete關鍵字用於從對象中移除屬性。對於delete關鍵字的性能,用戶已頗有微詞,不足之處預計在未來的更新中得到修復。你可以選擇簡單地將不需要的屬性設置為undefined。

const object = {name:"Jane Doe", age:43};

object.age = undefined;

也可以使用地圖(Map)對象,據布雷特所說,此種方式更為快捷。

7.最小化DOM訪問

與其他JavaScript語句相比,訪問DOM的速度很慢。對DOM進行更改會觸發布局的重新繪製,網站運行愈加緩慢。一次性訪問單個DOM元素並將其用作局部變量以減少訪問次數。任務完成後,務必將變量設置為null以移除該變量的值。這將觸發垃圾回收機制以防止內存洩漏。

8.壓縮文件

圖源:takscan

使用諸如Gzip之類的壓縮方法可縮小JavaScript文件的大小。鑑於瀏覽器所需下載資料縮小,網站性能也隨之提高。壓縮可將文件大小減少80%。

9.縮減最終代碼

有人認為縮減和壓縮是一樣的,事實並不是這樣。壓縮使用特殊算法來改變文件的輸出大小,縮減則需刪除JavaScript文件中的注釋和多餘空格。這一過程可以在許多工具和包的幫助下完成,這些工具和包都可以在網上找到。縮減已成為頁面優化的標準做法,也是前端優化的主要組成部分。

縮減可將文件大小減少60%。

10.使用節流(throtte)和去抖動(debounce)

節流和去抖動可嚴格控制代碼處理事件的次數。

節流指定函數可以超時的最大次數。例如,「每1000毫秒最多執行一次onkeyup事件函數。」這意味著如果每秒輸入20個鍵,事件每秒只會觸發一次,這將減少代碼的負載。

去抖動指定函數最小的持續時間,該時間是該函數自上一次執行後再次運行的時間。換句話說,「只有在經過600毫秒而沒有調用該函數的情況下,才會執行這個函數。」這就意味著自最後一次執行該函數起600毫秒內,該函數不會被調用。

11.使用異步和延遲

圖源:unsplash

現代網站中,腳本比超文本標記語言(HTML)更密集,大小更大,處理時間更長。默認情況下,瀏覽器必須等待腳本下載並執行後,再處理頁面的其餘部分。這可能會導致龐大的腳本阻止網頁加載。為避免這種情況,JavaScript提供了兩種名為異步和延遲的技術,您只需將這些屬性添加到<script >標籤中。

異步是告訴瀏覽器在不影響渲染的情況下加載腳本。換句話說,頁面不等待異步腳本,而是處理和顯示內容。延遲是在渲染完成後告訴瀏覽器加載腳本。如果兩者都有指定,異步在現代瀏覽器上處於優先地位,而支持延遲但不支持異步的舊瀏覽器將回退到延遲。

這兩個屬性可以極大地減少頁面加載時間。

12.使用異步代碼防止線程阻塞

JavaScript默認是同步的,也是單線程的。但有時代碼需要大量時間來計算。從本質上講,同步意味著一段代碼會阻止其他代碼語句運行,直到執行結束。這會降低網站整體性能。但是我們可以通過實施異步代碼避免這種情況。異步代碼曾以回調形式編寫,但ES6引入了一種處理異步代碼的新風格,名為promises。

但如何在單線程上運行的同時還能運行異步代碼?這是很多人困惑的地方。一切因運行在瀏覽器後臺的JavaScript引擎而成為可能。JavaScript引擎是執行JavaScript代碼的電腦程式或解釋器。JavaScript引擎可以用多種語言編寫。例如,支持谷歌瀏覽器的V8引擎是用C++編寫的,而支持火狐瀏覽器的蜘蛛猴引擎是用C和C++編寫的。

這些JavaScript引擎可以在後臺處理任務。據布萊恩所說,調用棧識別網絡應用程式界面(Web API)的功能,並遞交至瀏覽器處理。一旦瀏覽器完成了這些任務,它們就會返回並作為回調被壓入堆棧。

在沒有瀏覽器的情況下,Node.js如何運行?事實上,驅動谷歌瀏覽器的V8引擎也支持Node.js。

13.使用代碼拆分

圖源:unsplash

如果你有過谷歌燈塔(Light House)的經驗,必然會熟悉一個名為「初始內容渲染(first contentful paint)」的指標。這是燈塔報告性能部分跟蹤的六個指標之一。

初始內容渲染(FCP)測量的是用戶導航到頁面後,瀏覽器渲染第一個DOM內容所需的時間。頁面上的圖像、非白色<畫布>元素和可縮放矢量圖形(SVG)被視為DOM內容,iframe中的任何內容都不含在內。

獲得更高FCP分數的最佳方式之一是使用代碼拆分。代碼拆分是一種在開始時只向用戶發送必要模塊的技術。通過減小最初傳輸的有效載荷的大小而極大影響FCP分數。熱門的模塊管理器,如webpack,提供代碼拆分功能。也可在本機ES模塊的幫助下加載單個模塊。

14.使用Web Workers在後臺運行CPU密集型任務

Web Workers允許在後臺線程中運行腳本。如果你有一些高強度的任務,你可以把它們分配給Web Workers,Web Workers可以在不幹擾用戶界面的情況下運行這些任務。創建之後,Web Workers可以向JavaScript代碼指定的事件處理程序發送消息來與該代碼進行通信,反之亦然。

圖源:unsplash

掌握小技巧,快樂編碼吧!

留言點讚關注

我們一起分享AI學習與發展的乾貨

如轉載,請後臺留言,遵守轉載規範

相關焦點

  • javascript這些特點你知道其中幾個?建議前端小白好好看看!
    它是web開發中常用的腳本語言,特別是前端。 JavaScript主要功能是增強網頁互動性能,從而增加網站的用戶粘性。這是開發的初衷,但是後來就偏了大部分用到了web廣告上(各種彈窗廣告)。javascript有哪些特點?
  • JavaScript代碼優化5點小技巧一定掌握!
    以下是一些小貼士,以供你更好地優化JavaScript代碼,展現更好的性能。 順便一提,請確保共享和重用JS組件,以達成高質量代碼(需要時間來生成)和合理交付時間之間的恰當平衡。
  • 前端:用javascript實現一個轉盤小遊戲?
    本文轉載自【微信公眾號:趣談前端,ID:beautifulFront】經微信公眾號授權轉載,如需轉載與原文作者聯繫本文主要介紹如何使用原生javascript和Css3來實現一個在各大移動應用中經常出現的轉盤遊戲,由於改實現可以有不同方式,如果熟悉canvas的話也可以用canvas實現,本文採用js和css實現主要考慮到複雜度較小性能較好
  • 如何使用JavaScript實現前端導入和導出excel文件
    使用JavaScript實現前端導入excel文件並自動生成可編輯的Table組件在開始實現之前, 我們先來看看實現效果.1.2 實現一鍵導入excel文件並生成table表格導入excel文件的功能我們可以用javascript原生的方式實現解析, 比如可以用fileReader這些原生api,但考慮到開發效率和後期的維護, 筆者這裡採用antd的Upload組件和XLSX來實現上傳文件並解析的功能.
  • 20個常用的JavaScript簡寫技巧
    任何程式語言的簡寫技巧都能夠幫助你編寫更簡練的代碼,讓你用更少的代碼實現你的目標。讓我們一個個來看看 JavaScript 的簡寫技巧吧。 1. 聲明變量 2.
  • 騰訊歷史上首個專職前端開發:前端開發轉到雲上開發需要幾步?
    「20年前,前端有過一個最爽的時代,但那時前端是像BUG一樣的存在」,11月29日,由騰訊雲與微信聯合主辦的第二屆「小程序·雲開發」技術峰會現場,騰訊雲TVP、前端開發黃希彤現場分享了如何前端開發轉到雲上開發的發展歷程。
  • 0基礎學習JavaScript一定要知道如何使用VS2019去編寫代碼
    編寫JS代碼對於.NET開發者來說,前端技術也是不能少的,0基礎的開發者來說,使用Visual Studio 2019開發工具是非常容易上手的。這裡創建一個空白的Web應用程式項目,ASP.NET Web應用程式是完全支持JavaScript代碼編寫的。
  • 前端設計-JavaScript簡單數字時鐘開發實例
    簡單數字時鐘開發實例藉助於JavaScript window對象所提供的計時觸發函數setInterval可以實現前端動畫效果的設計與製作。本例主要以setInterval方法為基礎介紹簡單數字時鐘的開發實例。
  • 關於前端開發的20篇文檔與指南
    第一個來自於我們的個人感受,而第二個則是純粹的必要性了。所以本文整理一些有用的信息,希望可以幫助相關領域的前端開發人員。1. I want to use基於Can I use的數據和功能,這款應用給予你選擇一組前端開發特性的能力,並會讀取出一個全球性用戶能夠使用它的百分比。
  • Flutter 新功能、Dart 開發工具 及CSS 代碼
    本次大會以「代碼不止」為主題,全面介紹了產品更新以及一系列面向本地開發者的技術支持內容。11 月 18 日,進行了以 Flutter 為主題的演講,本文重點關注了 Flutter 性能方面的進展以及一些新功能。
  • IT30:中臺/軟體開發團隊40人員配置
    業務中臺40人開發團隊配置1、架構師:1名2、開發經理:1名3、開發主管:1名4、前端開發:7名5、後端開發:14名6、DBA系統性能優化,保障平臺安全,穩定,快速運行;4.對現有產品和系統進行改進和優化;3. 以架構角度把控系統的設計、落地以及運維,協調業務發展,統籌研發資源、把控系統實施節奏。前端開發 7名1.
  • 從前端性能優化引申出來的5道經典面試題
    渲染優化渲染優化是前端優化中一個很重要的部分,一個好的首屏時間能給用戶帶來很好的體驗,這裡要說的一點是關於首屏時間的定義,不同的團隊對首屏時間定義不一樣,有的團隊認為首屏時間就是白屏時間,是從頁面加載到第一個畫面出現的時間。
  • 如何設計理想的新項目前端開發流程?
    【51CTO.com快譯】一位前端開發者分享她的工作流與理想工具集選項。每個新項目總會帶來一段令人興奮的旅程,但糟糕的規劃也可能毀掉這一切。人們往往將前端開發工作流程視為繁瑣且優先級較低的任務,但由此帶來的後果往往會在生命周期當中出現。
  • 2020年最熱度最高的5個JavaScript框架
    簡而言之,框架是由一組開發人員編寫的代碼塊,以使整個開發過程變得簡單且易於實現。從業務角度看,它使開發人員能夠滿足相應客戶的需求,並使用框架來解決客戶項目開發階段所面臨的挑戰。基本上,在Vue中,開發人員可以將一些最佳功能組合在一起,例如將Angular,Ember和React的功能合而為一。它和Angular相似,提供了數據雙向綁定的功能。其中Vue的優點是體積小,可以輕鬆地輕鬆下載;使開發人員可以自由地在HTML文件中編寫其模板;簡單易學和簡單易懂的文檔支持。
  • CSS進階:提高你前端水平的 4 個技巧
    隨著 Node.js 、react-native 等技術的不斷出現,和網際網路行業的創業的層出不窮,了解些前端知識,成為全棧攻城師,快速的產出原型,展示你的創意,對程式設計師,尤其是在創業的程式設計師來說,越來越重要,下面我們就跟隨著名國外開發者網站上的熱推文章《Leveling up in CSS》,從提升你的CSS技巧開始。
  • 你應該知道的前端小知識
    近些年被廣泛的關注和探討,究其原因主要是因為現代化前端應用功能要求不斷提高,業務邏輯日益複雜,作為當下網際網路時代唯一不可或缺的技術,前端可以說是佔據了整個開發行業的半壁江山。從傳統的網站,到現在的H5,移動App,桌面應用,以及小程序。前端技術幾乎是無所不能的全面覆蓋。
  • 前端組件/庫打包利器rollup使用與配置實戰
    本文轉載自【微信公眾號:趣談前端,ID:beautifulFront】經微信公眾號授權轉載,如需轉載與原文作者聯繫目前主流的前端框架vue和react都採用rollup來打包,為了探索rollup的奧妙,接下來就讓我們一步步來探索,並基於rollup搭建一個庫打包腳手架,來發布自己的庫和組件。
  • 這一次,徹底弄懂 JavaScript 執行機制
    不論你是javascript新手還是老鳥,不論是面試求職,還是日常開發工作,我們經常會遇到這樣的情況:給定的幾行代碼,我們需要知道其輸出內容和順序。我們真的要徹底弄明白javascript的執行機制了。1.關於javascriptjavascript是一門單線程語言,在最新的HTML5中提出了Web-Worker,但javascript是單線程這一核心仍未改變。
  • 了解Android開發規範:性能及UI優化是什麼樣的?
    本文帶您全面了解Android開發規範,其中包括Android編碼規範,Android性能優化和Android UI優化,讀完絕對不會後悔的好文章。通用組件,放到styles.xml中;8.使用layer-list和selector9.圖片儘量分拆成多個可重用的圖片10.服務端可以實現的,就不要放在客戶端11.引用第三方庫要慎重,避免應用大容量的第三方庫,導致客戶端包非常大12.處理應用全局異常和錯誤,將錯誤以郵件的形式發送給服務端13.圖片的.9處理14
  • 前端開發者們值得了解的 11 項前端技巧
    通過以下 HTML/CSS/JavaScript 相關技巧,希望能幫助大家填補一點點關於前端開發方面的知識空白。 1.Datalist 元素 這項 HTML 元素的使用頻率極低,今天我們就要為它正名! 標籤用於為元素提供一項「自動補全」功能。