轉(zhuǎn)自:微點(diǎn)閱讀 https://www.weidianyuedu.com
JavaScript是運(yùn)行在客戶端的腳本,因此一般是不能夠設(shè)置Session的,因?yàn)镾ession是運(yùn)行在服務(wù)器端的。
而cookie是運(yùn)行在客戶端的,所以可以用JS來設(shè)置cookie.
假設(shè)有這樣一種情況,在某個(gè)用例流程中,由A頁面跳至B頁面,若在A頁面中采用JS用變量temp保存了某一變量的值,在B頁面的時(shí)候,同樣需要使用JS來引用temp的變量值,對于JS中的全局變量或者靜態(tài)變量的生命周期是有限的,當(dāng)發(fā)生頁面跳轉(zhuǎn)或者頁面關(guān)閉的時(shí)候,這些變量的值會(huì)重新載入,即沒有達(dá)到保存的效果。解決這個(gè)問題的最好的方案是采用cookie來保存該變量的值,那么如何來設(shè)置和讀取cookie呢?
首先需要稍微了解一下cookie的結(jié)構(gòu),簡單地說:cookie是以鍵值對的形式保存的,即key=value的格式。各個(gè)cookie之間一般是以“;”分隔。
JS設(shè)置cookie:
假設(shè)在A頁面中要保存變量username的值("jack")到cookie中,key值為name,則相應(yīng)的JS代碼為:
復(fù)制代碼代碼如下:
document.cookie="name="+username;
JS讀取cookie:
假設(shè)cookie中存儲(chǔ)的內(nèi)容為:name=jack;password=123
則在B頁面中獲取變量username的值的JS代碼如下:
?
1
2
3
4
5
6
7
8
9
10
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
?
1
2
3
4
5
6
7
8
function getCookie(name)
{
var arr,reg=new RegExp("(^| )"+name+"=([^;]*)(;|$)");
if(arr=document.cookie.match(reg))
return unescape(arr[2]);
else
return null;
}
刪除cookies
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
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"));
//如果需要設(shè)定自定義過期時(shí)間
//那么把上面的setCookie 函數(shù)換成下面兩個(gè)函數(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;
}
}
//這是有設(shè)定過期時(shí)間的使用示例:
//s20是代表20秒
//h是指小時(shí),如12小時(shí)則是:h12
//d是天數(shù),30天則:d30文章來源:http://www.zghlxwxcb.cn/news/detail-410165.html
setCookie("name","hayden","s20");文章來源地址http://www.zghlxwxcb.cn/news/detail-410165.html
到了這里,關(guān)于JS如何設(shè)置cookie、讀取cookie及刪除cookie的文章就介紹完了。如果您還想了解更多內(nèi)容,請?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!