<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當(dāng)前位置: 首頁 - 科技 - 知識(shí)百科 - 正文

        localStorage與sessionStorage五種循序漸進(jìn)的使用方法

        來源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-27 20:16:33
        文檔

        localStorage與sessionStorage五種循序漸進(jìn)的使用方法

        localStorage與sessionStorage五種循序漸進(jìn)的使用方法:需求:本地記錄用戶上次輸入的內(nèi)容使用關(guān)鍵技術(shù):localStorage第一步:使用jQuery的普通寫法1、JS代碼// 獲取window的localStorage對(duì)象var localS = window.localStorage;// 獲取localStorage的值var getV = localS.getIt
        推薦度:
        導(dǎo)讀localStorage與sessionStorage五種循序漸進(jìn)的使用方法:需求:本地記錄用戶上次輸入的內(nèi)容使用關(guān)鍵技術(shù):localStorage第一步:使用jQuery的普通寫法1、JS代碼// 獲取window的localStorage對(duì)象var localS = window.localStorage;// 獲取localStorage的值var getV = localS.getIt
        需求:本地記錄用戶上次輸入的內(nèi)容

        使用關(guān)鍵技術(shù):localStorage

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

        1、JS代碼

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

        2、效果圖

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

        第二步:使用JS函數(shù)方法來寫

        1、JS代碼

         1 // 所用到的變量統(tǒng)一寫在一起 2 var va,va2,getV,getV2; 3 // 設(shè)置localStorage方法 4 function localSet(){ 5 va = $(".value0").val(), 6 va2 = $(".value1").val(); 7 localStorage.setItem("value0",va); 8 localStorage.setItem("value1",va2); 9 };10 // 獲取localStorage方法11 function localGet(){12 getV = localStorage.getItem("value0"),13 getV2 = localStorage.getItem("value1");14 $(".value0").val(getV);15 $(".value1").val(getV2);16 }17 // 鍵盤按鍵彈起就設(shè)置localStorage的值18 $(document).on('keyup',function(){19 localSet();20 });21 // 頁面一加載就調(diào)用設(shè)置localStorage的方法22 localGet();

        2、效果圖

        3、嗯嗯...改為函數(shù)就很容易知道哪個(gè)是設(shè)置哪個(gè)是獲取localStorage了,還可以。不過,問題來了,我不想用函數(shù),我要用面向?qū)ο髮懛ǎ趺崔k??

        第三步:JS面向?qū)ο蟮膶懛?/p>

        1、JS代碼

         1 // 所用到的變量統(tǒng)一寫在一起 2 var va,va2,getV,getV2; 3 var localObj = { 4 // 設(shè)置localStorage方法 5 localSet : function(){ 6 va = $(".value0").val(), 7 va2 = $(".value1").val(); 8 localStorage.setItem("value0",va); 9 localStorage.setItem("value1",va2);10 },11 // 獲取localStorage方法12 localGet : function(){13 getV = localStorage.getItem("value0"),14 getV2 = localStorage.getItem("value1");15 $(".value0").val(getV);16 $(".value1").val(getV2);17 }18 }19 $(document).on('keyup',function(){20 localObj.localSet();21 });22 // 頁面一加載就調(diào)用設(shè)置localStorage的方法23 localObj.localGet();

        2、效果圖

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

        第四步:使用for循環(huán)的寫法

        1、JS代碼

         1 var localObj = { 2 // 設(shè)置localStorage方法 3 localSet : function(){ 4 // 我這里測(cè)試用的,所以直接選中所有的input長度,實(shí)際使用換成相同類名即可 5 for (var i = 0; i < $("input").length; i++) { 6 // 這里要注意,所有的localStorage的key都要相同,只是數(shù)字不同而已 7 localStorage.setItem("value"+i,$(".value"+i).val()); 8 } 9 },10 // 獲取localStorage方法11 localGet : function(){12 for (var i = 0; i < $("input").length; i++) {13 // 獲取對(duì)應(yīng)的key值,因?yàn)檫@里使用的是value+數(shù)字,所以直接這樣獲取即可14 $(".value"+i).val(localStorage.getItem("value"+i));15 }16 }17 }18 $(document).on('keyup',function(){19 localObj.localSet();20 });21 localObj.localGet();

        2、效果圖

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

        第五步:使用json來存放localStorage

        1、JS代碼

         1 var localObj = { 2 localSet: function(){ 3 // 定一個(gè)對(duì)象,來存放鍵值對(duì) 4 var arr = {}; 5 // 有多少個(gè)值,就對(duì)應(yīng)寫多少個(gè),名字可隨便命名 6 arr.value0 = $(".value0").val(); 7 arr.value1 = $(".value1").val(); 8 arr.good = $(".good").val(); 9 arr.go = $(".go").val();10 // 將arr對(duì)象轉(zhuǎn)換為string類型11 var his = JSON.stringify(arr);12 // 設(shè)置一個(gè)localStorage名字叫histroy,值為his13 localStorage.setItem("histroy",his);14 },15 localGet: function(){16 // 獲取一個(gè)叫histroy的localStorage,存放在arr變量中17 var arr = localStorage.getItem("histroy");18 // 把獲取來的arr轉(zhuǎn)換成json格式19 var json = JSON.parse(arr);20 // 遍歷Json中的數(shù)據(jù)21 for (var li in json) {22 // 由json字符串轉(zhuǎn)換為json對(duì)象23 var value = eval("json['" + li +"']");24 // 把取到的對(duì)應(yīng)的value值賦值給對(duì)應(yīng)的li25 arr.li = value;26 // 最后一步,顯示對(duì)應(yīng)的value值27 $("."+li).val(value);28 }29 }30 }31 // 鍵盤按鍵彈起的時(shí)候改變localStorage的值32 $(document).on('keyup',function(){33 localObj.localSet();34 });35 // 瀏覽器一打開就顯示存儲(chǔ)在localStorage里面的值36 // 即記錄上次輸入的值37 localObj.localGet();

        2、效果圖

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

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

          2) 百度翻譯使用的是多個(gè)數(shù)組來存放多個(gè)內(nèi)容,怎么弄??

          

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

        在HTML5中,新加入了一個(gè)localStorage和sessionStorage特性,這個(gè)特性主要是用來作為本地存儲(chǔ)來使用的,解決了cookie存儲(chǔ)空間不足的問題(cookie中每條cookie的存儲(chǔ)空間為4k),localStorage中一般瀏覽器支持的是5M大小,這個(gè)在不同的瀏覽器中l(wèi)ocalStorage和sessionStorage會(huì)有所不同。

        web storage和cookie的區(qū)別
        Web Storage的概念和cookie相似,區(qū)別是它是為了更大容量存儲(chǔ)設(shè)計(jì)的。Cookie的大小是受限的,并且每次你請(qǐng)求一個(gè)新的頁面的時(shí)候Cookie都會(huì)被發(fā)送過去,這樣無形中浪費(fèi)了帶寬,另外cookie還需要指定作用域,不可以跨域調(diào)用。
        除此之外,Web Storage擁有setItem,getItem,removeItem,clear等方法,不像cookie需要前端開發(fā)者自己封裝setCookie,getCookie。
        但是Cookie也是不可以或缺的:Cookie的作用是與服務(wù)器進(jìn)行交互,作為HTTP規(guī)范的一部分而存在 ,而Web Storage僅僅是為了在本地“存儲(chǔ)”數(shù)據(jù)而生

        聲明:本網(wǎng)頁內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        localStorage與sessionStorage五種循序漸進(jìn)的使用方法

        localStorage與sessionStorage五種循序漸進(jìn)的使用方法:需求:本地記錄用戶上次輸入的內(nèi)容使用關(guān)鍵技術(shù):localStorage第一步:使用jQuery的普通寫法1、JS代碼// 獲取window的localStorage對(duì)象var localS = window.localStorage;// 獲取localStorage的值var getV = localS.getIt
        推薦度:
        • 熱門焦點(diǎn)

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 亚洲综合日韩中文字幕v在线| 亚洲视频一区二区| 久久精品亚洲中文字幕无码网站| 免费大片av手机看片| 国产一区二区三区在线观看免费| 亚洲人成网站免费播放| 免费高清在线爱做视频| 在线91精品亚洲网站精品成人| 国产一区二区三区在线免费观看| 亚洲日韩看片无码电影| 永久中文字幕免费视频网站| 国产成人精品日本亚洲语音| 免费在线观看中文字幕| 成人自慰女黄网站免费大全| 亚洲AV无码国产精品色午友在线| 免费国产黄网站在线观看可以下载| 亚洲网站在线播放| 无码少妇一区二区浪潮免费| 亚洲国产精品无码中文lv| 免费少妇a级毛片| 国产又黄又爽又大的免费视频| 久久久无码精品亚洲日韩蜜桃| 18禁男女爽爽爽午夜网站免费| 中文文字幕文字幕亚洲色| 国产免费无遮挡精品视频| 一个人看的在线免费视频| 亚洲午夜精品一区二区| 野花高清在线电影观看免费视频| 精品亚洲成A人在线观看青青| 国产成人精品日本亚洲专区| 久久免费公开视频| 亚洲熟妇自偷自拍另欧美| 亚洲日韩在线中文字幕第一页| 久久午夜免费鲁丝片| 亚洲国产精品成人综合色在线| 国产成人综合亚洲AV第一页| 最近的中文字幕大全免费8| 亚洲AV无码一区二区三区牲色| 亚洲人成网77777亚洲色| 男女做羞羞的事视频免费观看无遮挡 | 亚洲Av无码乱码在线znlu|