知識大盤點:JS快取機制中的五個關鍵要點,需要具體程式碼範例
導語:在前端開發中,快取是提高網頁效能的重要一環。 JavaScript快取機制是指將已經取得的資源保存在本地,以便在後續的存取中能夠直接使用快取,從而減少資源載入時間和網路頻寬的消耗。本文將介紹JS快取機制中的關鍵要點,並提供具體的程式碼範例。
一、快取類型
- 強快取
強快取是指透過設定HTTP回應頭中的Expires或Cache-Control欄位來實現的緩存機制。當瀏覽器請求資源時,會先檢查該資源在本機是否存在緩存,如果存在且仍在有效期內,則直接使用緩存,不再發送請求。
範例程式碼:
// 设置缓存时间为1个小时 res.setHeader('Cache-Control', 'max-age=3600');
- 協商快取
#協商快取是透過設定HTTP請求頭中的If-Modified-Since或If-None- Match字段來與伺服器通訊的快取機制。當瀏覽器請求一個資源時,會先發送請求到伺服器,伺服器根據請求頭中的欄位和資源的最後修改時間進行比較,如果資源未發生變化,則傳回狀態碼304 Not Modified,並通知瀏覽器使用本機快取。
範例程式碼:
// 获取请求头中的If-Modified-Since字段 const ifModifiedSince = req.headers['if-modified-since']; // 获取资源的最后修改时间 const lastModified = fs.statSync(filepath).mtime.toUTCString(); // 比较请求头中的字段与最后修改时间 if (ifModifiedSince === lastModified) { res.statusCode = 304; // Not Modified res.end(); } else { res.setHeader('Last-Modified', lastModified); // 返回资源 res.end(file); }
二、快取位置
- 瀏覽器快取
瀏覽器快取是指快取在瀏覽器本地的快取檔案。當瀏覽器存取相同資源時,會先檢查該資源是否存在快取文件,如果存在則直接使用緩存,否則發送網路請求。
範例程式碼:
// 读取缓存 const cache = localStorage.getItem('cache'); // 判断缓存是否存在 if (cache) { // 使用缓存 } else { // 发送网络请求 }
- 伺服器快取
#伺服器快取是指快取在伺服器端的快取檔案。當瀏覽器請求資源時,伺服器會檢查該資源是否存在快取文件,如果存在則直接傳回快取文件。
範例程式碼:
// 判断文件是否存在 if (fs.existsSync(filepath)) { // 返回缓存文件 } else { // 发送网络请求 }
三、快取時間控制
- 快取時間
快取時間是指強快取或協商緩存的有效期限時間,可依需求設定不同的快取時間。
範例程式碼:
// 设置缓存时间为1个小时 res.setHeader('Cache-Control', 'max-age=3600');
- 快取策略
#快取策略是指根據資源類型或資源路徑設定不同的快取策略。可以使用正規表示式或字串匹配來實現不同的快取策略。
範例程式碼:
// 设置图片资源的缓存时间为1个月 if (req.url.match(/.jpg|.png|.gif$/)) { res.setHeader('Cache-Control', 'max-age=2592000'); }
四、快取更新
- 版本控制
版本控制是指在請求資源時新增版本號,當資源改變時更新版本號。透過更新版本號可以強制瀏覽器重新載入資源。
範例程式碼:
<!-- 添加版本号 --> <link rel="stylesheet" href="styles.css?v=1.0"> <script src="script.js?v=1.0"></script>
- 強制刷新
#強制刷新是指透過設定Cache-Control欄位的max-age為0來告訴瀏覽器立即更新快取。
範例程式碼:
// 强制刷新缓存 res.setHeader('Cache-Control', 'max-age=0');
五、快取清除
快取清除是指手動刪除瀏覽器本機的快取檔案或伺服器端的快取檔案。
範例程式碼:
// 清除浏览器缓存 localStorage.removeItem('cache'); // 清除服务器缓存 fs.unlinkSync(filepath);
總結:對於前端開發中常見的JS快取機制,我們介紹了五個關鍵要點,涉及的內容包括快取類型、快取位置、快取時間控制、快取更新和快取清除。掌握這些關鍵要點能夠幫助我們更能理解並應用快取機制,提升網頁效能,提升使用者體驗。希望透過本文的介紹,能對各位讀者有所幫助。
以上是JS快取機制的五個關鍵要點總結的詳細內容。更多資訊請關注PHP中文網其他相關文章!

Python和JavaScript的主要區別在於類型系統和應用場景。 1.Python使用動態類型,適合科學計算和數據分析。 2.JavaScript採用弱類型,廣泛用於前端和全棧開發。兩者在異步編程和性能優化上各有優勢,選擇時應根據項目需求決定。

選擇Python還是JavaScript取決於項目類型:1)數據科學和自動化任務選擇Python;2)前端和全棧開發選擇JavaScript。 Python因其在數據處理和自動化方面的強大庫而備受青睞,而JavaScript則因其在網頁交互和全棧開發中的優勢而不可或缺。

Python和JavaScript各有優勢,選擇取決於項目需求和個人偏好。 1.Python易學,語法簡潔,適用於數據科學和後端開發,但執行速度較慢。 2.JavaScript在前端開發中無處不在,異步編程能力強,Node.js使其適用於全棧開發,但語法可能複雜且易出錯。

javascriptisnotbuiltoncorc; sanInterpretedlanguagethatrunsonenginesoftenwritteninc.1)JavascriptwasdesignedAsignedAsalightWeight,drackendedlanguageforwebbrowsers.2)Enginesevolvedfromsimpleterterpretpretpretpretpreterterpretpretpretpretpretpretpretpretpretcompilerers,典型地,替代品。

JavaScript可用於前端和後端開發。前端通過DOM操作增強用戶體驗,後端通過Node.js處理服務器任務。 1.前端示例:改變網頁文本內容。 2.後端示例:創建Node.js服務器。

選擇Python還是JavaScript應基於職業發展、學習曲線和生態系統:1)職業發展:Python適合數據科學和後端開發,JavaScript適合前端和全棧開發。 2)學習曲線:Python語法簡潔,適合初學者;JavaScript語法靈活。 3)生態系統:Python有豐富的科學計算庫,JavaScript有強大的前端框架。

JavaScript框架的強大之處在於簡化開發、提升用戶體驗和應用性能。選擇框架時應考慮:1.項目規模和復雜度,2.團隊經驗,3.生態系統和社區支持。

引言我知道你可能會覺得奇怪,JavaScript、C 和瀏覽器之間到底有什麼關係?它們之間看似毫無關聯,但實際上,它們在現代網絡開發中扮演著非常重要的角色。今天我們就來深入探討一下這三者之間的緊密聯繫。通過這篇文章,你將了解到JavaScript如何在瀏覽器中運行,C 在瀏覽器引擎中的作用,以及它們如何共同推動網頁的渲染和交互。 JavaScript與瀏覽器的關係我們都知道,JavaScript是前端開發的核心語言,它直接在瀏覽器中運行,讓網頁變得生動有趣。你是否曾經想過,為什麼JavaScr


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具