如何進行 JavaScript 性能優化?

要進行 JavaScript 性能優化,我們可以從多個角度進行思考,主要包括減少頁面渲染時間、減少內存占用、優化代碼執行效率等。以下是優化的一些方法,并結合實際項目代碼示例講解。

目錄結構

  1. 減少 DOM 操作
    • 緩存 DOM 元素
    • 批量更新 DOM
  2. 優化 JavaScript 循環
    • 使用 for 循環替代 forEach
    • 減少不必要的循環
  3. 減少回流和重繪
    • 通過 requestAnimationFrame 控制動畫
    • 合并 DOM 更新
  4. 延遲加載和懶加載
    • 使用 IntersectionObserver
    • 圖片懶加載
  5. 避免內存泄漏
    • 使用 WeakMapWeakSet
  6. 異步操作優化
    • 使用 async/await
    • 減少回調地獄
  7. 代碼分割與懶加載
    • 使用 Webpack 等工具

1. 減少 DOM 操作

緩存 DOM 元素

頻繁訪問 DOM 元素會導致性能問題,尤其是在循環中,應該緩存常用的 DOM 元素。

// 非優化寫法
for (let i = 0; i < 1000; i++) {document.getElementById('my-element').textContent = 'Updated!';
}// 優化寫法
const myElement = document.getElementById('my-element');
for (let i = 0; i < 1000; i++) {myElement.textContent = 'Updated!';
}
批量更新 DOM

避免在循環中頻繁更新 DOM,使用文檔片段來減少渲染次數。

// 非優化寫法
for (let i = 0; i < 1000; i++) {const div = document.createElement('div');div.textContent = 'Item ' + i;document.body.appendChild(div);
}// 優化寫法
const fragment = document.createDocumentFragment();
for (let i = 0; i < 1000; i++) {const div = document.createElement('div');div.textContent = 'Item ' + i;fragment.appendChild(div);
}
document.body.appendChild(fragment);

2. 優化 JavaScript 循環

使用 for 循環替代 forEach

forEach 比傳統的 for 循環稍慢,尤其是對于大數組。

// 非優化寫法
const arr = [1, 2, 3, 4, 5];
arr.forEach(item => {console.log(item);
});// 優化寫法
for (let i = 0; i < arr.length; i++) {console.log(arr[i]);
}
減少不必要的循環

避免在每個循環中做不必要的計算,尤其是對于大數據量的處理。

// 非優化寫法
const arr = [1, 2, 3, 4, 5];
for (let i = 0; i < arr.length; i++) {if (arr[i] % 2 === 0) {console.log(arr[i]);}
}// 優化寫法
const evenNumbers = arr.filter(num => num % 2 === 0);
evenNumbers.forEach(num => console.log(num));

3. 減少回流和重繪

使用 requestAnimationFrame

動畫時,應使用 requestAnimationFrame 來優化性能,避免頻繁回流和重繪。

// 非優化寫法
function animate() {document.getElementById('box').style.left = parseInt(document.getElementById('box').style.left) + 1 + 'px';requestAnimationFrame(animate);
}// 優化寫法
function animate() {const box = document.getElementById('box');box.style.left = parseInt(box.style.left) + 1 + 'px';requestAnimationFrame(animate);
}
requestAnimationFrame(animate);
合并 DOM 更新

在修改樣式時,盡量批量處理,減少頁面的回流和重繪。

// 非優化寫法
element.style.height = '100px';
element.style.width = '200px';
element.style.backgroundColor = 'red';// 優化寫法
element.style.cssText = 'height: 100px; width: 200px; background-color: red;';

4. 延遲加載和懶加載

使用 IntersectionObserver

懶加載技術可以推遲圖片或其他資源的加載,減少頁面的初始加載時間。

const observer = new IntersectionObserver((entries, observer) => {entries.forEach(entry => {if (entry.isIntersecting) {const img = entry.target;img.src = img.getAttribute('data-src');observer.unobserve(img);}});
});const images = document.querySelectorAll('img.lazy');
images.forEach(image => observer.observe(image));

5. 避免內存泄漏

使用 WeakMapWeakSet

這些結構可以自動釋放不再使用的對象,避免內存泄漏。

// 使用 WeakMap 存儲對象
const weakMap = new WeakMap();
let obj = { name: 'test' };
weakMap.set(obj, 'some value');// 當 obj 失去引用時,自動銷毀
obj = null;

6. 異步操作優化

使用 async/await

避免回調地獄,提升異步操作的可讀性。

// 非優化寫法
fetch('url').then(response => response.json()).then(data => {console.log(data);});// 優化寫法
async function fetchData() {const response = await fetch('url');const data = await response.json();console.log(data);
}
fetchData();

7. 代碼分割與懶加載

使用 Webpack 進行代碼分割

大文件的 JavaScript 可以分割成多個較小的包,在需要時再加載,減少初始加載時間。

// Webpack 配置中啟用代碼分割
module.exports = {optimization: {splitChunks: {chunks: 'all',},},
};

總結

這些優化方法可以幫助提高 JavaScript 性能,尤其是在較為復雜的項目中,減少瀏覽器負擔、提升用戶體驗。通過精確分析瓶頸并逐步優化,最終可以實現更高效的前端應用。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/62139.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/62139.shtml
英文地址,請注明出處:http://en.pswp.cn/web/62139.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

CTF-PWN: 全保護下格式化字符串利用 [第一屆“吾杯”網絡安全技能大賽 如果能重來] 賽后學習(不會)

通過網盤分享的文件&#xff1a;如果能重來.zip 鏈接: https://pan.baidu.com/s/1XKIJx32nWVcSpKiWFQGpYA?pwd1111 提取碼: 1111 --來自百度網盤超級會員v2的分享漏洞分析 格式化字符串漏洞,在printf(format); __int64 sub_13D7() {char format[56]; // [rsp10h] [rbp-40h]…

selenium-常見問題解決方案匯總

selenium-常見問題解決方案 selenium版本selenium代理本地瀏覽器頁面Selenium之多窗口句柄的切換 selenium版本 selenium版本為: 3.141.0 注&#xff1a;selenium4x跟selenium3x會有不同的使用方法&#xff0c; selenium代理本地瀏覽器頁面 利用 Selenium 庫實現對 Google C…

Flask使用長連接

Flask使用flask_socketio實現websocket Python中的單例模式 在HTTP通信中&#xff0c;連接復用&#xff08;Connection Reuse&#xff09;是一個重要的概念&#xff0c;它允許客戶端和服務器在同一個TCP連接上發送和接收多個HTTP請求/響應&#xff0c;而不是為每個新的請求/響…

雨晨 26100.2454 Windows 11 24H2 專業工作站 極簡純凈版

文件: 雨晨 26100.2454 Windows 11 24H2 專業工作站極簡 install.esd 大小: 1947043502 字節 修改時間: 2024年12月6日, 星期五, 16:38:37 MD5: 339B7FDCA0130D432A0E98957738A9DD SHA1: 2978AE0CEAF02E52EC4135200D4BDBC861E07BE8 CRC32: 8C329C89 簡述&#xff1a; 由YCDIS…

[docker中首次配置git環境與時間同步問題]

11月沒寫東西&#xff0c;12月初趕緊水一篇。 剛開始搭建docker服務器時&#xff0c;網上找一堆指令配置好git后&#xff0c;再次新建容器后忘記怎么配了&#xff0c;&#xff0c;這次記錄下。 一、git ssh指令法&#xff0c;該方法不用每次提交時輸入密碼 前期準備&#xff0…

MongoDB性能監控工具

mongostat mongostat是MongoDB自帶的監控工具&#xff0c;其可以提供數據庫節點或者整個集群當前的狀態視圖。該功能的設計非常類似于Linux系統中的vmstat命令&#xff0c;可以呈現出實時的狀態變化。不同的是&#xff0c;mongostat所監視的對象是數據庫進程。mongostat常用于…

linux下的python打包

linux下的python打包 一、pyinstaller 優點&#xff1a;打包簡單&#xff0c;將整個運行環境進行打包 缺點&#xff1a;打包文件大、臃腫、啟動慢 安裝pyinstaller包 pip install pyinstaller 打包一個文件 pyinstaller -D app.py會在當前路徑中生成build、dist文件夾還有…

Python模塊之random、hashlib、json、time等內置模塊語法學習

Python內置模塊語法學習 random、hashlib、json、time、datetime、os等內置模塊語法學習 模塊 簡單理解為就是一個.py后綴的一個文件 分為三種&#xff1a; 內置模塊&#xff1a;python自帶&#xff0c;可調用第三方模塊&#xff1a;別人設計的&#xff0c;可調用自定義模塊…

從ctfwiki開始的pwn之旅 5.ret2csu

ret2csu 原理 在 64 位程序中&#xff0c;函數的前 6 個參數是通過寄存器傳遞的&#xff0c;但是大多數時候&#xff0c;我們很難找到每一個寄存器對應的 gadgets。 這時候&#xff0c;我們可以利用 x64 下的 __libc_csu_init 中的 gadgets。這個函數是用來對 libc 進行初始…

Ceph對象存儲

Ceph對象存儲1.概念對象存儲&#xff08;Object Storage&#xff09;是一種用于存儲大量非結構化數據的架構模型它使用簡單的HTTP或HTTPS協議進行文件訪問&#xff0c;而不是傳統的文件系統API與傳統的文件系統存儲方式不同&#xff0c;對象存儲不是將數據存儲在目錄或文件夾中…

嵌入式藍橋杯學習拓展 LCD翻轉顯示

通過配置SS和GS兩個標志位&#xff0c;實現掃描方向的切換。 將lcd.c的REG_932X_Init函數進行部分修改。 將LCD_WriteReg(R1, 0x0000);修改為LCD_WriteReg(R1,0x0100); 將LCD_WriteReg(R96, 0x2700); 修改為LCD_WriteReg(R96, 0xA700); void REG_932X_Init1(void) {LCD_Wr…

小程序 —— Day1

組件 — view和scroll-view view 類似于HTML中的div&#xff0c;是一個塊級元素 案例&#xff1a;通過view組件實現頁面的基礎布局 scroll-view 可滾動的視圖區域&#xff0c;用來實現滾動列表效果 案例&#xff1a;實現縱向滾動效果 scroll-x屬性&#xff1a;允許橫向滾動…

git pull error: cannot lock ref

Git: cannot lock ref ‘refs/remotes/origin/feature/xxx’: refs/remotes/origin/feature/xxx/car’ exists; cannot create refs/remotes/origin/feature/xxx git remote prune origin重新整理服務端和本地的關聯關系即可

pubmed關鍵詞搜索技能1:待更新

1&#xff0c;白話變為領域內學術詞&#xff1a; 例如&#xff0c;我想要做蛋白質糖基化修飾以功能&#xff0c;這個領域課題&#xff0c;則 第一性原理&#xff0c;首先是拆分詞匯&#xff1a;糖基化&#xff08;一般比蛋白質、修飾、功能要在title中更常見&#xff0c;或者是…

iPhone手機清理軟件:相冊清理大師推薦

隨著智能手機成為我們日常生活的必需品&#xff0c;手機中的數據日益膨脹&#xff0c;尤其是照片和視頻這類容易積累的文件。對于iPhone用戶來說&#xff0c;管理這些文件&#xff0c;特別是清理相冊變得尤為重要。本文將介紹一款備受推崇的iPhone手機清理軟件——CleanMyPhone…

SpringBoot 開源停車場管理收費系統

一、下載項目文件 下載源碼項目文件口令&#xff1a; 【前端小程序地址】(3.0)&#xff1a;伏脂火器白澤知洞座/~6f8d356LNL~:/【后臺管理地址】(3.0)&#xff1a;伏脂火器仇恨篆洞座/~0f4a356Ks2~:/【崗亭端地址】(3.0)&#xff1a;動作火器智匯堂多好/~dd69356K6r~:/復制口令…

網絡原理之 TCP 協議

目錄 1. TCP 協議格式 2. TCP 原理 (1) 確認應答 (2) 超時重傳 (3) 連接管理 a) 三次握手 b) 四次揮手 (4) 滑動窗口 (5) 流量控制 (6) 擁塞控制 (7) 延時應答 (8) 捎帶應答 3. TCP 特性 4. 異常情況的處理 1) 進程崩潰 2) 主機關機 (正常流程) 3) 主機掉電 (…

STM32使用RCC(Reset Clock Contorl,復位時鐘控制器)配置時鐘以及時鐘樹

RCC主要作用 設置系統時鐘SYSCLK&#xff08;System Clock&#xff09;頻率&#xff1b;設置AHB、APB2、APB1以及各個外設分頻因子&#xff0c;從而設置HCLK、PCLK2、PCLK1以及各個外設的時鐘頻率&#xff1b;控制AHB、APB2、APB1這三條總線時鐘以及每個外設的時鐘開啟&#xf…

安防視頻監控平臺Liveweb視頻匯聚管理系統管理方案

智慧安防監控Liveweb視頻管理平臺能在復雜的網絡環境中&#xff0c;將前端設備統一集中接入與匯聚管理。國標GB28181協議視頻監控/視頻匯聚Liveweb平臺可以提供實時遠程視頻監控、視頻錄像、錄像回放與存儲、告警、語音對講、云臺控制、平臺級聯、磁盤陣列存儲、視頻集中存儲、…

PostGIS的歷史發展

自從 GIS 軟件開發以來&#xff0c;ShapeFile等格式被廣泛用于存儲空間數據&#xff0c;但這些文件格式文件需要特殊的軟件才能讀取和寫入&#xff0c;并發用戶可能會導致數據損壞和速度變慢&#xff0c;并且復雜的問題需要復雜的軟件來處理。 因此&#xff0c;對多用戶的支持、…