JavaScript中cookie使用


轉自:http://www.cnblogs.com/yjzhu/archive/2012/11/26/2789032.html

 

一、什么是 cookie?

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

 

二、cookie 的特點

  1. 同個網站中所有的頁面共享一套 cookie;
  2. cookie 有數量、大小限制;
  3. cookie 有過期時間。

 

三、如何使用 cookie?

通過 document.cookie 來寫入 cookie

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

打開瀏覽器查看 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();
}

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM