一、什么是 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 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=abcdef@123.com'; typeof document.cookie; //string alert(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 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(); }
PS:附上 cookie 應用的小實例。點擊這里
更新(2017-02-02)
function cookie(name, value, opts) { if (typeof value !== 'undefined') { var expires = ''; opts = opts || {}; if (value === null) { value = ''; opts.expires = -1; } if (opts.expires) { var date = new Date(); date.setTime(date.getTime() + (opts.expires * 60 * 60 * 1000)); expires = '; expires=' + date.toGMTString(); } var path = opts.path ? '; path=' + opts.path : ''; var domain = opts.domain ? '; domain=' + opts.domain : ''; var secure = opts.secure ? '; secure' : ''; document.cookie = [name, '=', encodeURIComponent(value), expires, path, domain, secure].join(''); } else { var cookies; if (document.cookie && document.cookie !== '') { cookies = document.cookie.match(new RegExp('(^| )' + name + '=([^;]*)(;|$)')); if (cookies) { return decodeURIComponent(cookies[2]); } else { return null; } } } }
參數說明:
- name:讀取/寫入/刪除 cookie 的名稱
- value:需要設置 cookie 的值
- opts:其他參數,有效期 expires 單位小時,路徑 path,域名 domain,安全性 secure
- 返回值:有 cookie 就返回 cookie 的值,沒有返回 null
使用方法:
寫入 cookie
cookie('name', 'zhuyujia');
cookie('age', 29, {expires: 1});
讀取 cookie
cookie('name'); //'zhuyujia' cookie('age'); //29
刪除 cookie
只需要設置 cookie 的值為 null,就可以刪除相應的 cookie 了。
cookie('name', null); cookie('age', null);