javascript
JavaScript的Cookie操作
JavaScript是運行在客戶端的腳本,因此一般是不能夠設置Session的,因為Session是運行在服務器端的。
而cookie是運行在客戶端的,所以可以用JS來設置cookie.
假 設有這樣一種情況,在某個用例流程中,由A頁面跳至B頁面,若在A頁面中采用JS用變量temp保存了某一變量的值,在B頁面的時候,同樣需要使用JS來 引用temp的變量值,對于JS中的全局變量或者靜態(tài)變量的生命周期是有限的,當發(fā)生頁面跳轉(zhuǎn)或者頁面關閉的時候,這些變量的值會重新載入,即沒有達到保 存的效果。解決這個問題的最好的方案是采用cookie來保存該變量的值,那么如何來設置和讀取cookie呢?
首先需要稍微了解一下cookie的結(jié)構,簡單地說:cookie是以鍵值對的形式保存的,即key=value的格式。各個cookie之間一般是以“;”分隔。
JS設置cookie:
?
假設在A頁面中要保存變量username的值("jack")到cookie中,key值為name,則相應的JS代碼為:
document.cookie="name="+username;?
JS讀取cookie:
?
假設cookie中存儲的內(nèi)容為:name=jack;password=123
?
則在B頁面中獲取變量username的值的JS代碼如下:
var username=document.cookie.split(";")[0].split("=")[1];?
//JS操作cookies方法!
//寫cookies
function 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 函數(shù)換成下面兩個函數(shù)就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是天數(shù),30天則:d30
setCookie("name","hayden","s20");
轉(zhuǎn)載于:https://www.cnblogs.com/niceofday/p/5076218.html
總結(jié)
以上是生活随笔為你收集整理的JavaScript的Cookie操作的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: JavaScript的编码规范
- 下一篇: 肝S3 见异常信号灶(