解釋:

為什麼要使用網路儲存?

Web儲存提供了一種簡單有效的方法來增強使用者體驗。透過在客戶端儲存首選項、會話或其他必要數據,您可以創建更個人化、響應靈敏且無縫的 Web 應用程式。了解並利用 LocalStorage 和 SessionStorage 將幫助您建立更智慧的應用程序,滿足用戶需求,而無需嚴重依賴伺服器端儲存。

結論

LocalStorage 和 SessionStorage 是任何 Web 開發人員的必備工具。它們允許您直接在瀏覽器中儲存數據,從而在數據可用方式和時間方面提供靈活性。無論您需要保留使用者首選項還是維護特定於會話的信息,Web 儲存都可以讓您輕鬆完成此任務。透過掌握這些工具,您可以大幅增強 Web 應用程式的功能和使用者體驗。

","image":"http://www.luping.net/uploads/20240818/172395936366c1884370aa6.jpg","datePublished":"2024-08-18T13:36:03+08:00","dateModified":"2024-08-18T13:36:03+08:00","author":{"@type":"Person","name":"luping.net","url":"https://www.luping.net/articlelist/0_1.html"}}
」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > LocalStorage 和 SessionStorage 逐步指南:在客戶端儲存資料

LocalStorage 和 SessionStorage 逐步指南:在客戶端儲存資料

發佈於2024-08-18
瀏覽:760

A Step-by-Step Guide to LocalStorage and SessionStorage: Storing Data on the Client Side

網路儲存簡介

網路儲存是現代瀏覽器中的強大功能,可讓您直接在客戶端儲存資料。即使在瀏覽器關閉後(使用 LocalStorage)或僅在會話期間(使用 SessionStorage),也可以保留此資料。這些工具對於儲存使用者偏好、購物車資料和其他類型的增強使用者體驗的資訊非常有用。

LocalStorage 和 SessionStorage 之間的差異

了解 LocalStorage 和 SessionStorage 之間的差異是有效使用它們的關鍵:

  • 本地儲存:

    • 即使瀏覽器關閉後資料仍然存在。
    • 它可用於儲存長期數據,例如使用者偏好或令牌。
    • 儲存的資料沒有過期時間,並且在明確刪除之前一直可用。
  • 會話儲存:

    • 資料僅在會話期間可用(即,只要選項卡或瀏覽器視窗開啟)。
    • 會話結束(選項卡關閉)後,資料將自動清除。
    • 它對於臨時資料非常有用,例如特定於會話的使用者互動或選擇。

儲存、檢索和刪除數據

使用 LocalStorage 和 SessionStorage 非常簡單。以下範例示範如何儲存、檢索和刪除資料。

// Storing data
localStorage.setItem('username', 'john_doe');
sessionStorage.setItem('sessionID', '123456');

// Retrieving data
const username = localStorage.getItem('username');
const sessionID = sessionStorage.getItem('sessionID');

// Removing data
localStorage.removeItem('username');
sessionStorage.removeItem('sessionID');

// Clearing all data
localStorage.clear();
sessionStorage.clear();

真實範例:儲存使用者首選項

為了將這些概念付諸實踐,讓我們創建一個簡單的 Web 應用程序,允許用戶選擇並保存他們喜歡的主題(淺色或深色)。此首選項將使用 LocalStorage 進行存儲,以便即使在瀏覽器關閉後它仍然存在。

HTML:



  Theme Selector

Theme Selector

解釋:

  • 主題選擇:使用者可以透過點選對應的按鈕來選擇淺色或深色主題。
  • 儲存首選項:選擇主題後,它將儲存在 LocalStorage 中的「theme」鍵下。
  • 載入首選項:頁面載入時,腳本會檢查 LocalStorage 中是否有任何已儲存的主題並自動套用它。

為什麼要使用網路儲存?

Web儲存提供了一種簡單有效的方法來增強使用者體驗。透過在客戶端儲存首選項、會話或其他必要數據,您可以創建更個人化、響應靈敏且無縫的 Web 應用程式。了解並利用 LocalStorage 和 SessionStorage 將幫助您建立更智慧的應用程序,滿足用戶需求,而無需嚴重依賴伺服器端儲存。

結論

LocalStorage 和 SessionStorage 是任何 Web 開發人員的必備工具。它們允許您直接在瀏覽器中儲存數據,從而在數據可用方式和時間方面提供靈活性。無論您需要保留使用者首選項還是維護特定於會話的信息,Web 儲存都可以讓您輕鬆完成此任務。透過掌握這些工具,您可以大幅增強 Web 應用程式的功能和使用者體驗。

版本聲明 本文轉載於:https://dev.to/srijan_karki/a-step-by-step-guide-to-localstorage-and-sessionstorage-storing-data-on-the-client-side-2kjl?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • 為什麼「float: right」會顛倒 HTML 中的 Span 順序?
    為什麼「float: right」會顛倒 HTML 中的 Span 順序?
    Float:跨度的右反轉順序給定 HTML 標記:<div> <span class="label"><a href="/index/1">Bookmix Offline</a></span>...
    程式設計 發佈於2024-11-06
  • Python 字典如何保持程式碼乾淨、乾燥
    Python 字典如何保持程式碼乾淨、乾燥
    Python 字典和 DRY 原则:初学者快速指南 嘿! ?如果您正在深入研究 Python 编程,您可能偶然发现了字典,并且可能想知道“Python 中的字典到底是什么?它如何帮助我更智能地编写代码?”不用担心,让我们用一种超级简单的方式来分解它。 Python ...
    程式設計 發佈於2024-11-06
  • 使用 Django、Twilio 和 Pinata 建立安全的匿名回饋系統
    使用 Django、Twilio 和 Pinata 建立安全的匿名回饋系統
    在本指南中,我将引导您使用 Django、用于短信通知的 Twilio、用于安全媒体上传的 Pinata 以及用于响应式样式的 TailwindCSS 构建安全匿名反馈系统。在本教程结束时,您将拥有一个功能齐全的反馈系统,用户可以在其中提交反馈、选择上传媒体以及接收短信通知 - 所有这些都考虑到安全...
    程式設計 發佈於2024-11-06
  • 為什麼 Tkinter Entry 的 get 函數不回傳任何內容?
    為什麼 Tkinter Entry 的 get 函數不回傳任何內容?
    Tkinter Entry 的get 函數沒有產生任何結果:綜合解釋當嘗試使用get() 從Tkinter Entry 小部件檢索用戶輸入時函數時,您可能會遇到空返回值。這個看似令人困惑的問題源自於 Tkinter 的非同步特性和函數執行的順序。 在提供的程式碼片段中,您嘗試在建立 Entry 後立...
    程式設計 發佈於2024-11-06
  • 使用 NodeJs 開始使用 RabbitMq
    使用 NodeJs 開始使用 RabbitMq
    RabbitMq簡介 RabbitMq 是一個訊息代理,允許在不同服務之間發送和接收訊息。它是一個實作高階訊息佇列協定(AMQP)的訊息代理程式。用 Erlang 程式語言寫成。 安裝 RabbitMq RabbitMq 可以使用各自的套件管理器安裝在不同的作業系統上。 Rabbi...
    程式設計 發佈於2024-11-06
  • 讓網路更加互聯
    讓網路更加互聯
    讓網路更互聯 - Infometka 如何解決「隱形網站」問題 身為 Web 開發人員和 ???️??????️ 的創建者,我一直熱衷於解決現實世界的問題。今天,我想分享我開發的一個解決方案,我相信它可以為無數網站所有者帶來重大改變,並在某種程度上使互聯網成為一個更加互聯的地方。 ...
    程式設計 發佈於2024-11-06
  • 使用 React 建置 Loop Studio
    使用 React 建置 Loop Studio
    介绍 Loop Studio 是一个沉浸式网站,旨在展示各种虚拟现实 (VR) 项目。使用 React,我们可以有效地管理和渲染不同的组件,以构建有凝聚力和交互式的用户体验。该项目采用简洁的设计,带有导航标题、详细的 VR 部分、创作画廊以及带有社交媒体链接的页脚。 ...
    程式設計 發佈於2024-11-06
  • 如何解決用PHP在CURL中傳送多維數組時出現「陣列到字串轉換」錯誤?
    如何解決用PHP在CURL中傳送多維數組時出現「陣列到字串轉換」錯誤?
    透過CURL 和PHP 發送多維數組使用CURL 發布包含多維數組的表單資料時,遇到「數組到字串轉換」錯誤是一個常見問題。當嘗試使用包含陣列的陣列設定 CURLOPT_POSTFIELDS 時會發生這種情況。 由於 Content-Type 標頭必須是 multipart/form-data 以方便...
    程式設計 發佈於2024-11-06
  • 如何在 Selenium 中使用 \"span:contains(\'String\')\" 解決 InvalidSelectorException?
    如何在 Selenium 中使用 \"span:contains(\'String\')\" 解決 InvalidSelectorException?
    Selenium 中的Invalid SelectorException with "span:contains('String')"在Firefox 中使用Python 中的Selenium 時,嘗試使用CSS 選擇器「span:contains('Co...
    程式設計 發佈於2024-11-06
  • 如何將 HTML 附加到容器元素而不出現 InnerHTML 陷阱?
    如何將 HTML 附加到容器元素而不出現 InnerHTML 陷阱?
    在沒有innerHTML的情況下將HTML附加到容器元素重新訪問當前的問題是如何將HTML附加到容器元素,同時避免限制以及使用innerHTML屬性的陷阱。正如OP正確指出的那樣,innerHTML由於其替換現有內容的行為,可能會破壞嵌入媒體等動態元素。 幸運的是,有一個替代方案可以克服這些問題:i...
    程式設計 發佈於2024-11-06
  • 持續測試:確保 DevOps 管道的質量
    持續測試:確保 DevOps 管道的質量
    持续测试是现代软件开发中的关键实践,尤其是在 DevOps 框架内。它涉及在整个软件交付管道中自动执行测试,以确保对代码库所做的每项更改都得到彻底验证。通过将测试集成到开发过程的每个阶段,持续测试旨在尽早发现和解决缺陷,从而显着降低生产故障的风险。 什么是持续测试? 持续测试是作为软件交付管道的一...
    程式設計 發佈於2024-11-06
  • 背景顏色改變視頻
    背景顏色改變視頻
    在 Instagram 上關注我們 在本影片教學中,我將指導您使用 HTML、CSS 和 JavaScript 建立令人驚嘆的 Instagram 卡片。這張卡片具有充滿活力的變色邊框、圓形個人資料圖片和「關注我們」按鈕,為您的線上形象增添了吸引力。該專案非常適合增強您的作品集或社交媒體頁面,展示了...
    程式設計 發佈於2024-11-06
  • 如何使用 PHP 清除瀏覽器快取?
    如何使用 PHP 清除瀏覽器快取?
    使用 PHP 清除瀏覽器快取瀏覽器快取將經常存取的檔案儲存在本地,從而縮短網站載入時間。但是,如果快取的檔案已過時,它也會幹擾測試和開發。本文說明如何使用 PHP 清除瀏覽器快取。 清除瀏覽器快取的PHP 碼以下PHP 代碼將標頭髮送到客戶端瀏覽器,指示其清除其快取:header("Cac...
    程式設計 發佈於2024-11-06
  • AWS Lambda 與 Go,初始樣板
    AWS Lambda 與 Go,初始樣板
    照片由 Lukáš Vaňátko 在 Unsplash 上拍摄 介绍 Go 由于其简单性一直是我最喜欢的语言之一。最近,我决定弄清楚如何使用用 Go 编写的 lambda 函数创建一个简单的样板无服务器项目。我对工具和开发人员体验很好奇。 目标 我想创建一个 RES...
    程式設計 發佈於2024-11-06
  • 在 Laravel 中對底部為空值和非空值的行進行降序排序
    在 Laravel 中對底部為空值和非空值的行進行降序排序
    使用資料庫時,經常會遇到某些欄位可能為空或 NULL 的情況。經常出現的一個挑戰是如何對記錄進行排序,以便具有空字段的行出現在結果集的底部,而具有非空值的行以有意義的方式排序(例如,降序)。在這篇文章中,我將透過一個實際範例向您展示如何在 Laravel 中實現這一目標。 設想 假...
    程式設計 發佈於2024-11-06

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3