DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> JavaScript基礎知識 >> javascript cookie用法基礎教程(概念,設置,讀取及刪除)
javascript cookie用法基礎教程(概念,設置,讀取及刪除)
編輯:JavaScript基礎知識     

本文實例講述了javascript cookie用法。分享給大家供大家參考,具體如下:

一、什麼是 cookie?

cookie 就是頁面用來保存信息,比如自動登錄、記住用戶名等等。

二、cookie 的特點

同個網站中所有的頁面共享一套 cookie

cookie 有數量、大小限制

cookie 有過期時間

三、如何使用 cookie?

通過 document.cookie 來寫入 cookie

<!DOCTYPE HTML>
<html lang="en-US">
<head>
 <meta charset="UTF-8">
 <title>cookie基礎</title>
</head>
<body>
</body>
</html>
<script type="text/javascript">
document.cookie = 'username=abc';
document.cookie = 'password=123';
document.cookie = '[email protected]';
</script>

打開浏覽器查看 cookie,可以發現新定義的 cookie 並不會將原來的覆蓋。

如果沒有設置過期時間,那麼關閉浏覽器就會清空 cookie。如何設置過期時間呢?答案是:expires。一般我們會結合 Date 對象來使用。

var d = new Date();
d.setTime(d.getTime() + 1 * 3600 * 1000);
document.cookie = 'username=abc; expires=' + d.toGMTString();

我們可以通過火狐浏覽器看到,username 的過期時間是當前時間的 1 小時後。

最後對獲取 cookie 的方法進行封裝:

function setCookie(name,value,hours){ 
 var d = new Date();
 d.setTime(d.getTime() + hours * 3600 * 1000);
 document.cookie = name + '=' + value + '; expires=' + d.toGMTString();
}

學會了如何設置 cookie,那麼該如何讀取 cookie 呢?

首先我們看下 cookie 裡的內容是什麼類型?

document.cookie = 'username=abc';
document.cookie = 'password=123';
document.cookie = '[email protected]';
typeof document.cookie; //string
alert(document.cookie); //'username=abc; password=123; [email protected]'

得到的是一串字符串,需要注意的是,每個 ; 後面都有個空格。

那麼我們如何取到具體的數值呢?附上代碼:

function getCookie(name){ 
 var arr = document.cookie.split('; ');
 for(var i = 0; i < arr.length; i++){
 var temp = arr[i].split('=');
 if(temp[0] == name){
  return temp[1];
 }
 }
 return '';
}

除了設置、獲取 cookie,我們還可以刪除 cookie。我們在網上經常看到有清除用戶名這樣的功能,其實就是用到了清除 cookie。

清除 cookie 其實很簡單,只要使過期時間為過去時間就可以了。

function removeCookie(name){
 var d = new Date();
 d.setTime(d.getTime() - 10000);
 document.cookie = name + '=1; expires=' + d.toGMTString();
}

最後我們將設置、獲取、清除 cookie 封裝成一個 cookie.js

function setCookie(name,value,hours){ 
 var d = new Date();
 d.setTime(d.getTime() + hours * 3600 * 1000);
 document.cookie = name + '=' + value + '; expires=' + d.toGMTString();
}
function getCookie(name){ 
 var arr = document.cookie.split('; ');
 for(var i = 0; i < arr.length; i++){
 var temp = arr[i].split('=');
 if(temp[0] == name){
  return temp[1];
 }
 }
 return '';
}
function removeCookie(name){
 var d = new Date();
 d.setTime(d.getTime() - 10000);
 document.cookie = name + '=1; expires=' + d.toGMTString();
}

附:這裡再補充一個關於cookie的基礎應用:javascript cookie記錄用戶名

更多關於JavaScript相關內容感興趣的讀者可查看本站專題:《JavaScript中json操作技巧總結》、《JavaScript切換特效與技巧總結》、《JavaScript查找算法技巧總結》、《JavaScript動畫特效與技巧匯總》、《JavaScript錯誤與調試技巧總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript數學運算用法總結》

希望本文所述對大家JavaScript程序設計有所幫助。

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved