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