JavaScript之cookie技術詳解_javascript技巧

來源:互聯網
上載者:User

運用JS設定cookie、讀取cookie、刪除cookie
JavaScript是運行在用戶端的指令碼,因此一般是不能夠設定Session的,因為Session是運行在伺服器端的。

而cookie是運行在用戶端的,所以可以用JS來設定cookie.

假設有這樣一種情況,在某個用例流程中,由A頁面跳至B頁面,若在A頁面中採用JS用變數temp儲存了某一變數的值,在B頁面的時候,同樣需要使用JS來引用temp的變數值,對於JS中的全域變數或者靜態變數的生命週期是有限的,當發生頁面跳轉或者頁面關閉的時候,這些變數的值會重新載入,即沒有達到儲存的效果。解決這個問題的最好的方案是採用cookie來儲存該變數的值,那麼如何來設定和讀取cookie呢?
首先需要稍微瞭解一下cookie的結構,簡單地說:cookie是以索引值對的形式儲存的,即key=value的格式。各個cookie之間一般是以“;”分隔。

JS設定cookie:

假設在A頁面中要儲存變數username的值(“jack”)到cookie中,key值為name,則相應的JS代碼為:
document.cookie="name="+username; 

JS讀取cookie:
假設cookie中儲存的內容為:name=jack;password=123

則在B頁面中擷取變數username的值的JS代碼如下:

var username=document.cookie.split(";")[0].split("=")[1]; //JS操作cookies方法!//寫cookiesfunction setCookie(name,value) {   var Days = 30;   var exp = new Date();   exp.setTime(exp.getTime() + Days*24*60*60*1000);   document.cookie = name + "="+ escape (value) + ";expires=" + exp.toGMTString(); }//讀取cookies function getCookie(name) {   var arr,reg=new RegExp("(^| )"+name+"=([^;]*)(;|$)");  if(arr=document.cookie.match(reg))    return unescape(arr[2]);   else     return null; }//刪除cookies function delCookie(name) {   var exp = new Date();   exp.setTime(exp.getTime() - 1);   var cval=getCookie(name);   if(cval!=null)     document.cookie= name + "="+cval+";expires="+exp.toGMTString(); } //使用樣本 setCookie("name","hayden"); alert(getCookie("name"));//如果需要設定自訂到期時間 //那麼把上面的setCookie 函數換成下面兩個函數就ok;//程式碼 function setCookie(name,value,time){   var strsec = getsec(time);   var exp = new Date();   exp.setTime(exp.getTime() + strsec*1);   document.cookie = name + "="+ escape (value) + ";expires=" + exp.toGMTString(); } function getsec(str){   alert(str);   var str1=str.substring(1,str.length)*1;   var str2=str.substring(0,1);   if (str2=="s")  {     return str1*1000;   }  else if (str2=="h")  {     return str1*60*60*1000;   }  else if (str2=="d")  {     return str1*24*60*60*1000;   } } 
//這是有設定到期時間的使用樣本: //s20是代表20秒 //h是指小時,如12小時則是:h12 //d是天數,30天則:d30setCookie(“name”,”hayden”,”s20”);

以上就是本文的全部內容,希望對大家的學習有所協助,也希望大家多多支援雲棲社區。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.