如果您想訂閱本博客內容,每天自動發到您的郵箱中, 請點這里
1、cookie的作用:
我們在瀏覽器中,經常涉及到數據的交換,比如你登錄郵箱,登錄一個頁面。我們經常會在此時設置30天內記住我,或者自動登錄選項。那么它們是怎么記錄信息的呢,答案就是今天的主角cookie了,Cookie是由HTTP服務器設置的,保存在瀏覽器中,但HTTP協議是一種無狀態協議,在數據交換完畢后,服務器端和客戶端的鏈接就會關閉,每次交換數據都需要建立新的鏈接。就像我們去超市買東西,沒有積分卡的情況下,我們買完東西之后,超市沒有我們的任何消費信息,但我們辦了積分卡之后,超市就有了我們的消費信息。cookie就像是積分卡,可以保存積分,商品就是我們的信息,超市的系統就像服務器后臺,http協議就是交易的過程。
2、機制的區別:
session機制采用的是在服務器端保持狀態的方案,而cookie機制則是在客戶端保持狀態的方案,cookie又叫會話跟蹤機制。打開一次瀏覽器到關閉瀏覽器算是一次會話。說到這里,講下HTTP協議,前面提到,HTTP協議是一種無狀態協議,在數據交換完畢后,服務器端和客戶端的鏈接就會關閉,每次交換數據都需要建立新的鏈接。此時,服務器無法從鏈接上跟蹤會話。cookie可以跟蹤會話,彌補HTTP無狀態協議的不足。
3、cookie的分類:
cookie分為會話cookie和持久cookie,會話cookie是指在不設定它的生命周期expires時的狀態,前面說了,瀏覽器的開啟到關閉就是一次會話,當關閉瀏覽器時,會話cookie就會跟隨瀏覽器而銷毀。當關閉一個頁面時,不影響會話cookie的銷毀。會話cookie就像我們沒有辦理積分卡時,單一的買賣過程,離開之后,信息則銷毀。
持久cookie則是設定了它的生命周期expires,此時,cookie像商品一樣,有個保質期,關閉瀏覽器之后,它不會銷毀,直到設定的過期時間。對于持久cookie,可以在同一個瀏覽器中傳遞數據,比如,你在打開一個淘寶頁面登陸后,你在點開一個商品頁面,依然是登錄狀態,即便你關閉了瀏覽器,再次開啟瀏覽器,依然會是登錄狀態。這就是因為cookie自動將數據傳送到服務器端,在反饋回來的結果。持久cookie就像是我們辦理了一張積分卡,即便離開,信息一直保留,直到時間到期,信息銷毀。
4、簡單的使用cookie的代碼
cookie的幾種常見屬性:document.cookie="key=value;expires=失效時間;path=路徑;domain=域名;secure;(secure表安全級別),
cookie以字符串的形式保存在瀏覽器中。下面貼段代碼出來,是一個類似購物網站的將商品添加到購物車,再從購物車還原商品信息的過程,是自己用原生JS封裝的函數。
封裝的cookie的存入,讀取以及刪除的函數:(這里是將信息以對象的形式存放到cookie中的,會用到JSON的知識)
-
-
-
-
-
-
-
-
-
-
function cookie(key, value, options) {
-
-
-
if (typeof value === "undefined") {
-
-
var cookies = document.cookie.split("; ");
-
-
for (var i = 0, len = cookies.length; i < len; i++) {
-
-
-
-
var cookie = cookies[i].split("=");
-
-
if (decodeURIComponent(cookie[0]) === key) {
-
return decodeURIComponent(cookie[1]);
-
}
-
}
-
-
return null;
-
}
-
-
-
-
options = options || {};
-
-
var cookie = encodeURIComponent(key) + "=" + encodeURIComponent(value);
-
-
if ((typeof options.expires) !== "undefined") {
-
if (typeof options.expires === "number") {
-
var days = options.expires,
-
t = options.expires = new Date();
-
t.setDate(t.getDate() + days);
-
}
-
cookie += ";expires=" + options.expires.toUTCString();
-
}
-
-
if (typeof options.path !== "undefined")
-
cookie += ";path=" + options.path;
-
-
if (typeof options.domain !== "undefined")
-
cookie += ";domain=" + options.domain;
-
-
if (options.secure)
-
cookie += ";secure";
-
-
-
document.cookie = cookie;
-
}
-
-
-
function removeCookie(key, options) {
-
options = options || {};
-
options.expires = -1;
-
cookie(key, "", options);
-
}
下面是商品詳情頁的JS代碼
-
-
var links = $("a", $("#tab"));
-
-
for (var i = 0, len = links.length; i < len; i++) {
-
links[i].onclick = function(){
-
-
var _cells = this.parentNode.parentNode.cells;
-
-
var _id = _cells[0].innerHTML,
-
_name = _cells[1].innerHTML,
-
_price = _cells[2].innerHTML;
-
-
var product = {
-
id : _id,
-
name : _name,
-
price : _price,
-
amount : 1
-
};
-
-
-
-
var _products = cookie("products");
-
if (_products === null)
-
_products = [];
-
else
-
_products = JSON.parse(_products);
-
-
-
_products.push(product);
-
-
cookie("products", JSON.stringify(_products), {expires:7});
-
}
-
}
html代碼,css代碼大家可以自己寫
-
<table id="tab">
-
<tr>
-
<td>序號</td>
-
<td>名稱</td>
-
<td>價格</td>
-
<td>操作</td>
-
</tr>
-
<tr>
-
<td>1</td>
-
<td>空調</td>
-
<td>3999</td>
-
<td><a href="javascript:void(0);">添加到購物車</a></td>
-
</tr>
-
<tr>
-
<td>2</td>
-
<td>風扇</td>
-
<td>288</td>
-
<td><a href="javascript:void(0);">添加到購物車</a></td>
-
</tr>
-
</table>
-
<a href="cart_購物車.html" target="_blank">查看購物車</a>
購物車還原商品信息:
-
-
var _products = cookie("products");
-
-
if (_products === null || (_products = JSON.parse(_products)).length === 0)
-
return;
-
-
-
$(".result")[0].innerHTML = "";
-
for (var i = 0, len = _products.length; i < len; i++) {
-
-
var prod = _products[i];
-
-
var _row = $(".row")[0].cloneNode(true);
-
-
$(".index", _row)[0].innerHTML = prod.id;
-
$(".name", _row)[0].innerHTML = prod.name;
-
$(".price", _row)[0].innerHTML = prod.price;
-
$(".amount", _row)[0].innerHTML = prod.amount;
-
$(".oper", _row)[0].innerHTML = "<a href='javascript:void(0);'>刪除</a>"
-
-
-
$(".result")[0].appendChild(_row);
-
};
-
-
-
var links = $("a", $("#container"));
-
for (var i = 0, len = links.length; i < len; i++) {
-
-
links[i].product = _products[i];
-
links[i].onclick = function(){
-
-
var index = inArray(this.product, _products);
-
-
if (index !== -1) {
-
_products.splice(index, 1);
-
}
-
-
cookie("products", JSON.stringify(_products), {expires:7});
-
-
-
var _row = this.parentNode.parentNode;
-
_row.parentNode.removeChild(_row);
-
};
-
}
這里的$(' ')函數是自己封裝的函數,用于獲取到DOM節點,可以看下我關于getElementsByClassName的兼容那篇文章。
藍藍設計( ssll180.com )是一家專注而深入的界面設計公司,為期望卓越的國內外企業提供卓越的UI界面設計、BS界面設計 、 cs界面設計 、 ipad界面設計 、 包裝設計 、 圖標定制 、 用戶體驗 、交互設計、 網站建設 、平面設計服務