一、什麼是 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 = abcdef@123.com';</script>
開啟瀏覽器查看 cookie,可以發現新定義的 cookie 並不會將原來的覆蓋。
如果沒有設定到期時間,那麼關閉瀏覽器就會清空 cookie。如何設定到期時間呢?答案是:expires。一般我們會結合 Date 對象來使用。
var oDate = new Date();oDate.setDate(oDate.getDate() + 30);document.cookie = 'username = abc;expires = ' + oDate;
我們可以通過Firefox瀏覽器看到,username 的到期時間是目前時間的 30 天后。
最後對擷取 cookie 的方法進行封裝:
function setCookie(name, value, iDay){ var oDate = new Date(); oDate.setDate(oDate.getDate() + iDay); document.cookie = name + '=' + value + ';expires = ' + oDate;}
學會了如何設定 cookie,那麼該如何讀取 cookie 呢?
首先我們看下 cookie 裡的內容是什麼類型?
document.cookie = 'username = abc';document.cookie = 'password = 123';document.cookie = 'email = abcdef@123.com';typeof document.cookie; //stringalert(document.cookie); //'username=abc; password=123; email=abcdef@123.com'
得到的是一串字串,需要注意的是,每個 ; 後面都有個空格。
那麼我們如何取到具體的數值呢?附上代碼:
function getCookie(name){ var arr = document.cookie.split('; '); for(var i = 0; i < arr.length; i++){ var arr2 = arr[i].split('='); if(arr2[0] == name){ return arr2[1]; } } return '';}
除了設定、擷取 cookie,我們還可以刪除 cookie。我們在網上經常看到有清除使用者名稱這樣的功能,其實就是用到了清除 cookie。
清除 cookie 其實很簡單,只要使到期時間為昨天就可以了。通過前面封裝的 setCookie 來設定。
function removeCookie(name){ setCookie(name,'1',-1);}
最後我們將設定、擷取、清除 cookie 封裝成一個 cookie.js
//設定cookiefunction setCookie(name,value,iDay){ var oDate = new Date(); oDate.setDate(oDate.getDate() + iDay); document.cookie = name + '=' + value + ';expires = ' + oDate;}//讀取cookiefunction getCookie(name){ var arr = document.cookie.split('; '); for(var i = 0; i < arr.length; i++){ var arr2 = arr[i].split('='); if(arr2[0] == name){ return arr2[1]; } } return '';}//清除cookiefunction removeCookie(name){ setCookie(name,'1',-1);}
PS:附上 cookie 應用的小執行個體。點擊這裡