HTML 本地存儲-7.3HTML API
閱讀 ?·? 發布日期 2019-07-11 12:48 ?·? adminHTML 本地存儲:優于 cookies。
什么是 HTML 本地存儲?
通過本地存儲(Local Storage),web 應用程序能夠在用戶瀏覽器中對數據進行本地的存儲。
在 HTML5 之前,應用程序數據只能存儲在 cookie 中,包括每個服務器請求。本地存儲則更安全,并且可在不影響網站性能的前提下將大量數據存儲于本地。
與 cookie 不同,存儲限制要大得多(至少5MB),并且信息不會被傳輸到服務器。
本地存儲經由起源地(origin)(經由域和協議)。所有頁面,從起源地,能夠存儲和訪問相同的數據。
瀏覽器支持
表格中的數組指示了完全支持本地存儲的首個瀏覽器版本。
API | |||||
Web Storage | 4.0 | 8.0 | 3.5 | 4.0 | 11.5 |
HTML 本地存儲對象
HTML 本地存儲提供了兩個在客戶端存儲數據的對象:
- window.localStorage - 存儲沒有截止日期的數據
- window.sessionStorage - 針對一個 session 來存儲數據(當關閉瀏覽器標簽頁時數據會丟失)
在使用本地存儲時,請檢測 localStorage 和 sessionStorage 的瀏覽器支持:
if (typeof(Storage) !== "undefined") { // 針對 localStorage/sessionStorage 的代碼 } else { // 抱歉!不支持 Web Storage .. }
localStorage 對象
localStorage 對象存儲的是沒有截止日期的數據。當瀏覽器被關閉時數據不會被刪除,在下一天、周或年中,都是可用的。
實例
// 存儲 localStorage.setItem("lastname", "Gates"); // 取回 document.getElementById("result").innerHTML = localStorage.getItem("lastname");
實例解釋:
- 創建 localStorage 名稱/值對,其中:name="lastname",value="Gates"
- 取回 "lastname" 的值,并把它插到 id="result" 的元素中
上例也可這樣寫:
// 存儲 localStorage.lastname = "Gates"; // 取回 document.getElementById("result").innerHTML = localStorage.lastname;
刪除 "lastname" localStorage 項目的語法如下:
localStorage.removeItem("lastname");
注釋:名稱/值對始終存儲為字符串。如果需要請記得把它們轉換為其他格式!
下面的例子對用戶點擊按鈕的次數進行計數。在代碼中,值字符串被轉換為數值,依次對計數進行遞增:
實例
if (localStorage.clickcount) { localStorage.clickcount = Number(localStorage.clickcount) + 1; } else { localStorage.clickcount = 1; } document.getElementById("result").innerHTML = "您已經點擊這個按鈕 " + localStorage.clickcount + " 次。";
sessionStorage 對象
sessionStorage 對象等同 localStorage 對象,不同之處在于只對一個 session 存儲數據。如果用戶關閉具體的瀏覽器標簽頁,數據也會被刪除。
下例在當前 session 中對用戶點擊按鈕進行計數:
實例
if (sessionStorage.clickcount) { sessionStorage.clickcount = Number(sessionStorage.clickcount) + 1; } else { sessionStorage.clickcount = 1; } document.getElementById("result").innerHTML = "在本 session 中,您已經點擊這個按鈕 " + sessionStorage.clickcount + " 次。";
為您推薦
- 襯塑管網站建設_網頁定制制作與開發 2020-01-12
- 保溫管網站建設_網頁定制制作與開發 2020-01-12
- 玻璃管網站建設_網頁定制制作與開發 2020-01-12
- 鍍鋅方矩管網站建設_網頁定制制作與 2020-01-12
- PVC管材網站建設_網頁定制制作與開發 2020-01-12