一、概述 HTML5 提供了兩種在客戶端存儲數據的新方法: localStorage - 沒有時間限制的數據存儲 sessionStorage - 針對一個 session 的數據存儲 之前,這些都是由 cookie 完成的。但是 cookie 不適合大量數據的存儲,因為它們由每個對伺服器的請求來傳 ...
一、概述
HTML5 提供了兩種在客戶端存儲數據的新方法:
- localStorage - 沒有時間限制的數據存儲
- sessionStorage - 針對一個 session 的數據存儲
之前,這些都是由 cookie 完成的。但是 cookie 不適合大量數據的存儲,因為它們由每個對伺服器的請求來傳遞,這使得 cookie 速度很慢而且效率也不高。
在 HTML5 中,數據不是由每個伺服器請求傳遞的,而是只有在請求時使用數據。它使在不影響網站性能的情況下存儲大量數據成為可能。
對於不同的網站,數據存儲於不同的區域,並且一個網站只能訪問其自身的數據。
HTML5 使用 JavaScript 來存儲和訪問數據。
/************************源自w3c****************************/
二、用法小結
(一)設置值
1. localStorage.setItem(key,value):如果key的value存在時,更新key的值,例:localStorage.setItem("name","moomoo");【推薦寫法】
2. localStorage.name = "moomoo";
3. localStorage["name"] = "moomoo";
(二)獲取值
1. localStorage.getItem(key,value):如果key的value不存在時,返回null,例:localStorage.getItem("name");【推薦寫法】
2. var name = localStorage.name;
3. var name = localStorage["name"];
(三)清除值
1. localStorage.remove(key),表示清除單項key的值,例:localStorage.remove("name");執行這句話就會清除name的值
2. localStorage.clear(),表示清除localStorage存儲的所有數據
(四)遍歷存儲的數據
當你不清楚本地localStorage存儲了多少數據的時候,用key(index)方法絕對是一個不錯的選擇,key(index)方法可以遍歷localStorage存儲的key。寫個簡單的例子:
for(i=0;i<localStorage.length;i++){
document.write(localStorage.key(i)+":"+localStorage.getItem(localStorage.key(i))+"<br/>");
}
localStorage.length表示本地存儲數據的總量;
localStorage.key(i),表示獲取第i個數據的key;
localStorage.getItem(localStorage.key(i)),表示獲取第i個數據的value。
(五)JSON存儲
當需要存儲的數據很多時,可以將數據存儲到數組中並轉換成JSON格式的數據。
1. JSON.stringify(data) 將對象轉換成JSON格式的數據串。
2. JSON.parse(data)將數據解析成對象並返回解析後的對象。
這樣說或許不太好懂,直接上例子:
var arr = {"name":"moomoo","age":2,"eat":"apple"};
localStorage.setItem("arr",JSON.stringify(arr));
arr = JSON.parse(localStorage.getItem("arr"));
如果想要確定這些信息是否真的存儲在瀏覽器本地,拿谷歌舉例:在瀏覽器空白處右擊,選擇檢查(直接上圖好了)
這樣就可以很方便的審查存儲在本地的數據了。
不過需要註意的是:localStorage存儲的數據是不能跨瀏覽器共用的,也就是說存儲在瀏覽器的數據只能在這個瀏覽器中訪問,現在各個瀏覽器的存儲空間是5M。
(六)sessionStorage
sessionStorage是個全局對象,它維護著在頁面會話(page session)期間有效的存儲空間。只要瀏覽器開著,頁面會話周期就會一直持續。當頁面重新載入(reload)或者被恢復(restores)時,頁面會話也是一直存在的。每在新標簽或者新視窗中打開一個新頁面,都會初始化一個新的會話,也就是說sessionStorage針對一個 session 進行數據存儲。當用戶關閉瀏覽器視窗後,數據會被刪除。
當瀏覽器被意外刷新的時候,一些臨時數據應當被保存和恢復。sessionStorage 對象在處理這種情況的時候是最有用的。sessionStorage自動保存一個文本域中的內容,如果瀏覽器被意外刷新,則恢復該文本域中的內容,所以不會丟失任何輸入的數據。
sessionStorage 方法與localStorage的方法相似,這裡就不過多贅述。
(七)相容性
如圖可知並不是所有的瀏覽器都支持。如果你想在沒有原生支持localStorage對象的瀏覽器中使用它,可以在你編寫的 JavaScript代碼的首部插入下麵兩段代碼中的任意一段。
if (!window.localStorage) { Object.defineProperty(window, "localStorage", new (function () { var aKeys = [], oStorage = {}; Object.defineProperty(oStorage, "getItem", { value: function (sKey) { return sKey ? this[sKey] : null; }, writable: false, configurable: false, enumerable: false }); Object.defineProperty(oStorage, "key", { value: function (nKeyId) { return aKeys[nKeyId]; }, writable: false, configurable: false, enumerable: false }); Object.defineProperty(oStorage, "setItem", { value: function (sKey, sValue) { if(!sKey) { return; } document.cookie = escape(sKey) + "=" + escape(sValue) + "; path=/"; }, writable: false, configurable: false, enumerable: false }); Object.defineProperty(oStorage, "length", { get: function () { return aKeys.length; }, configurable: false, enumerable: false }); Object.defineProperty(oStorage, "removeItem", { value: function (sKey) { if(!sKey) { return; } var sExpDate = new Date(); sExpDate.setDate(sExpDate.getDate() - 1); document.cookie = escape(sKey) + "=; expires=" + sExpDate.toGMTString() + "; path=/"; }, writable: false, configurable: false, enumerable: false }); this.get = function () { var iThisIndx; for (var sKey in oStorage) { iThisIndx = aKeys.indexOf(sKey); if (iThisIndx === -1) { oStorage.setItem(sKey, oStorage[sKey]); } else { aKeys.splice(iThisIndx, 1); } delete oStorage[sKey]; } for (aKeys; aKeys.length > 0; aKeys.splice(0, 1)) { oStorage.removeItem(aKeys[0]); } for (var iCouple, iKey, iCouplId = 0, aCouples = document.cookie.split(/\s*;\s*/); iCouplId < aCouples.length; iCouplId++) { iCouple = aCouples[iCouplId].split(/\s*=\s*/); if (iCouple.length > 1) { oStorage[iKey = unescape(iCouple[0])] = unescape(iCouple[1]); aKeys.push(iKey); } } return oStorage; }; this.configurable = false; this.enumerable = true; })()); }
或
if (!window.localStorage) { window.localStorage = { getItem: function (sKey) { if (!sKey || !this.hasOwnProperty(sKey)) { return null; } return unescape(document.cookie.replace(new RegExp("(?:^|.*;\\s*)" + escape(sKey).replace(/[\-\.\+\*]/g, "\\$&") + "\\s*\\=\\s*((?:[^;](?!;))*[^;]?).*"), "$1")); }, key: function (nKeyId) { return unescape(document.cookie.replace(/\s*\=(?:.(?!;))*$/, "").split(/\s*\=(?:[^;](?!;))*[^;]?;\s*/)[nKeyId]); }, setItem: function (sKey, sValue) { if(!sKey) { return; } document.cookie = escape(sKey) + "=" + escape(sValue) + "; path=/"; this.length = document.cookie.match(/\=/g).length; }, length: 0, removeItem: function (sKey) { if (!sKey || !this.hasOwnProperty(sKey)) { return; } var sExpDate = new Date(); sExpDate.setDate(sExpDate.getDate() - 1); document.cookie = escape(sKey) + "=; expires=" + sExpDate.toGMTString() + "; path=/"; this.length--; }, hasOwnProperty: function (sKey) { return (new RegExp("(?:^|;\\s*)" + escape(sKey).replace(/[\-\.\+\*]/g, "\\$&") + "\\s*\\=")).test(document.cookie); } }; window.localStorage.length = (document.cookie.match(/\=/g) || window.localStorage).length; }
大家自行領會……這兩段……表示不懂/(ㄒoㄒ)/~~