国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

JS中LocalStorage與SessionStorage五種循序漸進的使用方法

2019-11-19 16:06:17
字體:
來源:轉載
供稿:網友

localStorage和sessionStorage一樣都是用來存儲客戶端臨時信息的對象。

他們均只能存儲字符串類型的對象(雖然規范中可以存儲其他原生類型的對象,但是目前為止沒有瀏覽器對其進行實現)。

localStorage生命周期是永久,這意味著除非用戶顯示在瀏覽器提供的UI上清除localStorage信息,否則這些信息將永遠存在。

sessionStorage生命周期為當前窗口或標簽頁,一旦窗口或標簽頁被永久關閉了,那么所有通過sessionStorage存儲的數據也就被清空了。

不同瀏覽器無法共享localStorage或sessionStorage中的信息。相同瀏覽器的不同頁面間可以共享相同的localStorage(頁面屬于相同域名和端口),但是不同頁面或標簽頁間無法共享sessionStorage的信息。這里需要注意的是,頁面及標簽頁僅指頂級窗口,如果一個標簽頁包含多個iframe標簽且他們屬于同源頁面,那么他們之間是可以共享sessionStorage的。

需求:本地記錄用戶上次輸入的內容

使用關鍵技術:localStorage

第一步:使用jQuery的普通寫法

1、JS代碼

// 獲取window的localStorage對象var localS = window.localStorage;// 獲取localStorage的值var getV = localS.getItem("value0"), getV2 = localS.getItem("value1");// 把獲取到的值賦給對應的input$(".value0").val(getV);$(".value1").val(getV2);// 鍵盤按鍵彈起就設置localStorage的值$(document).on("keyup",function(){ // 一個輸入框對應一個value值 var va = $(".value0").val(),  va2 = $(".value1").val(); // 有多少個就設置setItem多少個 localS.setItem("value0",va); localS.setItem("value1",va2);});

2、效果圖

3、額額...可以用,不過,問題來了,這JS代碼寫的...有點亂啊,后期不好維護啊有木有!怎么辦??有什么辦法可以解決??

第二步:使用JS函數方法來寫

1、JS代碼

// 所用到的變量統一寫在一起var va,va2,getV,getV2;// 設置localStorage方法function localSet(){ va = $(".value0").val(), va2 = $(".value1").val(); localStorage.setItem("value0",va); localStorage.setItem("value1",va2);};// 獲取localStorage方法function localGet(){ getV = localStorage.getItem("value0"), getV2 = localStorage.getItem("value1"); $(".value0").val(getV); $(".value1").val(getV2);}// 鍵盤按鍵彈起就設置localStorage的值$(document).on('keyup',function(){ localSet();});// 頁面一加載就調用設置localStorage的方法localGet();

2、效果圖

3、嗯嗯...改為函數就很容易知道哪個是設置哪個是獲取localStorage了,還可以。不過,問題來了,我不想用函數,我要用面向對象寫法,怎么辦??

第三步:JS面向對象的寫法

1、JS代碼

// 所用到的變量統一寫在一起var va,va2,getV,getV2;var localObj = { // 設置localStorage方法 localSet : function(){  va = $(".value0").val(),  va2 = $(".value1").val();  localStorage.setItem("value0",va);  localStorage.setItem("value1",va2); }, // 獲取localStorage方法 localGet : function(){  getV = localStorage.getItem("value0"),  getV2 = localStorage.getItem("value1");  $(".value0").val(getV);  $(".value1").val(getV2); }}$(document).on('keyup',function(){ localObj.localSet();});// 頁面一加載就調用設置localStorage的方法localObj.localGet();

2、效果圖

3、哈哈...改了一下就好了,還蠻簡單的嘛!不過,問題來了,如果有很多個input框需要記錄,那豈不是得寫很多代碼?能不能循環處理一下??

第四步:使用for循環的寫法

1、JS代碼

var localObj = { // 設置localStorage方法 localSet : function(){  // 我這里測試用的,所以直接選中所有的input長度,實際使用換成相同類名即可  for (var i = 0; i < $("input").length; i++) {   // 這里要注意,所有的localStorage的key都要相同,只是數字不同而已   localStorage.setItem("value"+i,$(".value"+i).val());  } }, // 獲取localStorage方法 localGet : function(){  for (var i = 0; i < $("input").length; i++) {   // 獲取對應的key值,因為這里使用的是value+數字,所以直接這樣獲取即可   $(".value"+i).val(localStorage.getItem("value"+i));  } }}$(document).on('keyup',function(){ localObj.localSet();});localObj.localGet();

2、效果圖

3、呦呦...想加多少個,就加多少個value,還不錯呦,代碼又比較簡潔。不過,問題又來了。我不想一直使用類名value+數字,我已經有寫好了的類名了,我想用什么名字就用什么名字,而且不想弄一大堆localStorage,難道有100個input,就要我弄100個localStorage??我就想弄一個localStorage記錄就好。怎么辦??

第五步:使用json來存放localStorage

1、JS代碼

var localObj = { localSet: function(){  // 定一個對象,來存放鍵值對  var arr = {};   // 有多少個值,就對應寫多少個,名字可隨便命名   arr.value0 = $(".value0").val();   arr.value1 = $(".value1").val();   arr.good = $(".good").val();   arr.go = $(".go").val();  // 將arr對象轉換為string類型  var his = JSON.stringify(arr);  // 設置一個localStorage名字叫histroy,值為his  localStorage.setItem("histroy",his); }, localGet: function(){  // 獲取一個叫histroy的localStorage,存放在arr變量中  var arr = localStorage.getItem("histroy");  // 把獲取來的arr轉換成json格式  var json = JSON.parse(arr);  // 遍歷Json中的數據  for (var li in json) {   // 由json字符串轉換為json對象   var value = eval("json['" + li +"']");   // 把取到的對應的value值賦值給對應的li   arr.li = value;   // 最后一步,顯示對應的value值   $("."+li).val(value);  } }}// 鍵盤按鍵彈起的時候改變localStorage的值$(document).on('keyup',function(){ localObj.localSet();});// 瀏覽器一打開就顯示存儲在localStorage里面的值// 即記錄上次輸入的值localObj.localGet();

2、效果圖

3、哇~,不錯不錯,到第五步,基本就已經解決了我們的需求了,不過(TMD還有問題?)哈哈哈哈。。。

  1)假設不單單是input要記錄上次輸入內容,復選框CheckBox也要記錄是否上次被選中的問題,怎么解決??

  2) 百度翻譯使用的是多個數組來存放多個內容,怎么弄??

 

最后:如果使用sessionStorage,直接把localStorage替換成sessionStorage就好了,其它的一模一樣?。?!

以上所述是小編給大家介紹的JS中LocalStorage與SessionStorage五種循序漸進的使用方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 阿克| 洛隆县| 安远县| 厦门市| 芮城县| 定安县| 大埔县| 达孜县| 离岛区| 荆州市| 内黄县| 盐池县| 敦煌市| 京山县| 上犹县| 阜平县| 资溪县| 广汉市| 固阳县| 榕江县| 阳谷县| 北流市| 普兰县| 昆明市| 金乡县| 库伦旗| 上饶市| 左权县| 门头沟区| 洞口县| 青海省| 水城县| 鄢陵县| 新兴县| 加查县| 咸阳市| 宣威市| 平谷区| 镇赉县| 宜良县| 鹤山市|