下面小編就為大家?guī)?lái)一篇關(guān)于cookie的初識(shí)和運(yùn)用(js和jq)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。
cookie是什么
---------------------------------------------------
cookie是瀏覽器提供的一種機(jī)制,它將document 對(duì)象的cookie屬性提供給JavaScript??梢杂蒍avaScript對(duì)其進(jìn)行控制,而并不是JavaScript本身的性質(zhì)。cookie是存于用戶(hù)硬盤(pán)的一個(gè)文件,這個(gè)文件通常對(duì)應(yīng)于一個(gè)域名,當(dāng)瀏覽器再次訪(fǎng)問(wèn)這個(gè)域名時(shí),便使這個(gè)cookie可用。因此,cookie可以跨越一個(gè)域名下的多個(gè)網(wǎng)頁(yè),但不能跨越多個(gè)域名使用。
cookie使用場(chǎng)合
---------------------------------------------------
(1)保存用戶(hù)登錄狀態(tài)。例如將用戶(hù)id存儲(chǔ)于一個(gè)cookie內(nèi),這樣當(dāng)用戶(hù)下次訪(fǎng)問(wèn)該頁(yè)面時(shí)就不需要重新登錄了,現(xiàn)在很多論壇和社區(qū)都提供這樣的功能。 cookie還可以設(shè)置過(guò)期時(shí)間,當(dāng)超過(guò)時(shí)間期限后,cookie就會(huì)自動(dòng)消失。因此,系統(tǒng)往往可以提示用戶(hù)保持登錄狀態(tài)的時(shí)間:常見(jiàn)選項(xiàng)有一個(gè)月、三個(gè) 月、一年等。
(2)跟蹤用戶(hù)行為。例如一個(gè)天氣預(yù)報(bào)網(wǎng)站,能夠根據(jù)用戶(hù)選擇的地區(qū)顯示當(dāng)?shù)氐奶鞖馇闆r。如果每次都需要選擇所在地是煩瑣的,當(dāng)利用了 cookie后就會(huì)顯得很人性化了,系統(tǒng)能夠記住上一次訪(fǎng)問(wèn)的地區(qū),當(dāng)下次再打開(kāi)該頁(yè)面時(shí),它就會(huì)自動(dòng)顯示上次用戶(hù)所在地區(qū)的天氣情況。因?yàn)橐磺卸际窃诤?臺(tái)完成,所以這樣的頁(yè)面就像為某個(gè)用戶(hù)所定制的一樣,使用起來(lái)非常方便。
(3)定制頁(yè)面。如果網(wǎng)站提供了換膚或更換布局的功能,那么可以使用cookie來(lái)記錄用戶(hù)的選項(xiàng),例如:背景色、分辨率等。當(dāng)用戶(hù)下次訪(fǎng)問(wèn)時(shí),仍然可以保存上一次訪(fǎng)問(wèn)的界面風(fēng)格。
cookie的用法
---------------------------------------------------
js方式:
function setCookie(sName, sValue, oExpires, sPath, sDomain, bSecure) { //js設(shè)置cookie
var sCookie = sName + '=' + encodeURIComponent(sValue);
if (oExpires) {
var date = new Date();
date.setTime(date.getTime() + oExpires * 60 * 60 * 1000);
sCookie += '; expires=' + date.toUTCString();
}
if (sPath) {
sCookie += '; path=' + sPath;
if (sDomain) {
sCookie += '; domain=' + sDomain;
}
if (bSecure) {
sCookie += '; secure';
}
document.cookie = sCookie;
}
function getCookie(name){ //獲取cookie
var strCookie=document.cookie;
var arrCookie=strCookie.split("; ");
for(var i=0;i<arrCookie.length;i++){
var arr=arrCookie[i].split("=");
if(arr[0]==name){
return decodeURIComponent(arr[1]);
}
}
return "";
}
function delCookie(name){//刪除cookie
// 該函數(shù)檢查下cookie是否設(shè)置,如果設(shè)置了則將過(guò)期時(shí)間調(diào)到過(guò)去的時(shí)間;
//剩下就交給操作系統(tǒng)適當(dāng)時(shí)間清理cookie啦
if (getCookie(name))
{
document.cookie = name + "=" + "; expires=Thu, 01-Jan-70 00:00:01 GMT";
}
}
jq插件方式:
jq官網(wǎng)http://plugins.jquery.com/搜索cookie插件,幾k的大小,使用非常方便:
<script type="text/javascript" src="js/jquery.js"></script>
<script type="text/javascript" src="js/jquery.cookie.js"></script>
在引入以上庫(kù)文件后,使用方式如下:
<script>
$.cookie('the_cookie'); //讀取Cookie值
$.cookie('the_cookie', 'the_value'); //設(shè)置cookie的值
$.cookie('the_cookie', 'the_value', {expires: 7, path: '/', domain: 'jquery.com', secure: true});//新建一個(gè)cookie 包括有效期 路徑 域名等
$.cookie('the_cookie', 'the_value'); //新建cookie
$.cookie('the_cookie', null); //刪除一個(gè)cookie
</script>
以上這篇關(guān)于cookie的初識(shí)和運(yùn)用(js和jq)就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考