HTML5 本地存儲

HTML 本地存儲:優於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 + " 次。";

親自試一試

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。 必填欄位標示為 *