javascript操作cookie方法函數(shù)集合第1/2頁
更新時間:2010年07月08日 02:28:03 作者:
很多朋友需要使用到cookies操作,腳本之家以前也發(fā)表了不少相關(guān)的文章。這篇文章,雖然亂了點,但知識點比較多。
問題:
使得在訪問頁面的時候能夠沿用上次的設(shè)置,或者在不同的頁面間共享數(shù)據(jù)。比如用戶在訪問網(wǎng)站的時候設(shè)置了頁面字體的大小,那么會希望下次訪問的時候仍然能使用同樣的設(shè)置進(jìn)行瀏覽,而不用重復(fù)設(shè)置。
解決方案:
在用戶瀏覽頁面并進(jìn)行設(shè)置時,將這些設(shè)置保存在cookie中,下次訪問的時候讀取cookie中的設(shè)置。
參考下面的腳本:
// utility function to retrieve an expiration data in proper format;
function getExpDate(days, hours, minutes)
{
var expDate = new Date();
if(typeof(days) == "number" && typeof(hours) == "number" && typeof(hours) == "number")
{
expDate.setDate(expDate.getDate() + parseInt(days));
expDate.setHours(expDate.getHours() + parseInt(hours));
expDate.setMinutes(expDate.getMinutes() + parseInt(minutes));
return expDate.toGMTString();
}
}
//utility function called by getCookie()
function getCookieVal(offset)
{
var endstr = document.cookie.indexOf(";", offset);
if(endstr == -1)
{
endstr = document.cookie.length;
}
return unescape(document.cookie.substring(offset, endstr));
}
// primary function to retrieve cookie by name
function getCookie(name)
{
var arg = name + "=";
var alen = arg.length;
var clen = document.cookie.length;
var i = 0;
while(i < clen)
{
var j = i + alen;
if (document.cookie.substring(i, j) == arg)
{
return getCookieVal(j);
}
i = document.cookie.indexOf(" ", i) + 1;
if(i == 0) break;
}
return;
}
// store cookie value with optional details as needed
function setCookie(name, value, expires, path, domain, secure)
{
document.cookie = name + "=" + escape(value) +
((expires) ? "; expires=" + expires : "") +
((path) ? "; path=" + path : "") +
((domain) ? "; domain=" + domain : "") +
((secure) ? "; secure" : "");
}
// remove the cookie by setting ancient expiration date
function deleteCookie(name,path,domain)
{
if(getCookie(name))
{
document.cookie = name + "=" +
((path) ? "; path=" + path : "") +
((domain) ? "; domain=" + domain : "") +
"; expires=Thu, 01-Jan-70 00:00:01 GMT";
}
}
使用getCookie(name)函數(shù)來讀取cookie中保存的值,參數(shù)name為cookie項的名稱。如果該cookie項不存在則返回一個空字符串。
使用setCookie()函數(shù)來保存cookie項的值,其中第一、二兩個參數(shù)分別為cookie項的名稱和值。如果想為其設(shè)置一個過期時間,那么就需要設(shè)置第三個參數(shù),這里需要通過getExpDate()獲得一個正確格式的參數(shù)。
最后,使用deleteCookie()來刪除一個已存在的cookie項,實際上是通過讓該項過期。
cookie將數(shù)據(jù)保存在客戶端。頁面的腳本只能讀取所在域和服務(wù)器的cookie值,如果域內(nèi)有多個服務(wù)器,那么需要設(shè)置第五個參數(shù),以指定服務(wù)器。瀏覽器的容量一般限定為每服務(wù)器20個name/value對,每個cookie項不超過4000個字符,更現(xiàn)實點,單個cookie項應(yīng)少于2000字符,也就是說不要用cookie在客戶端保存大容量數(shù)據(jù)。
不同的瀏覽器保存cookie的方式也有所不同。IE為每個域的cookie建立一個文本文件,而Netscape則將所有的cookie存儲在同一個文本文件中。
注意:cookie存放在客戶端,所以會受到瀏覽器設(shè)置的影響,比如用戶可能會禁用cookie。要檢測瀏覽器是否支持cookie,使用屬性navigator.cookieEnabled來判斷。
使得在訪問頁面的時候能夠沿用上次的設(shè)置,或者在不同的頁面間共享數(shù)據(jù)。比如用戶在訪問網(wǎng)站的時候設(shè)置了頁面字體的大小,那么會希望下次訪問的時候仍然能使用同樣的設(shè)置進(jìn)行瀏覽,而不用重復(fù)設(shè)置。
解決方案:
在用戶瀏覽頁面并進(jìn)行設(shè)置時,將這些設(shè)置保存在cookie中,下次訪問的時候讀取cookie中的設(shè)置。
參考下面的腳本:
復(fù)制代碼 代碼如下:
// utility function to retrieve an expiration data in proper format;
function getExpDate(days, hours, minutes)
{
var expDate = new Date();
if(typeof(days) == "number" && typeof(hours) == "number" && typeof(hours) == "number")
{
expDate.setDate(expDate.getDate() + parseInt(days));
expDate.setHours(expDate.getHours() + parseInt(hours));
expDate.setMinutes(expDate.getMinutes() + parseInt(minutes));
return expDate.toGMTString();
}
}
//utility function called by getCookie()
function getCookieVal(offset)
{
var endstr = document.cookie.indexOf(";", offset);
if(endstr == -1)
{
endstr = document.cookie.length;
}
return unescape(document.cookie.substring(offset, endstr));
}
// primary function to retrieve cookie by name
function getCookie(name)
{
var arg = name + "=";
var alen = arg.length;
var clen = document.cookie.length;
var i = 0;
while(i < clen)
{
var j = i + alen;
if (document.cookie.substring(i, j) == arg)
{
return getCookieVal(j);
}
i = document.cookie.indexOf(" ", i) + 1;
if(i == 0) break;
}
return;
}
// store cookie value with optional details as needed
function setCookie(name, value, expires, path, domain, secure)
{
document.cookie = name + "=" + escape(value) +
((expires) ? "; expires=" + expires : "") +
((path) ? "; path=" + path : "") +
((domain) ? "; domain=" + domain : "") +
((secure) ? "; secure" : "");
}
// remove the cookie by setting ancient expiration date
function deleteCookie(name,path,domain)
{
if(getCookie(name))
{
document.cookie = name + "=" +
((path) ? "; path=" + path : "") +
((domain) ? "; domain=" + domain : "") +
"; expires=Thu, 01-Jan-70 00:00:01 GMT";
}
}
使用getCookie(name)函數(shù)來讀取cookie中保存的值,參數(shù)name為cookie項的名稱。如果該cookie項不存在則返回一個空字符串。
使用setCookie()函數(shù)來保存cookie項的值,其中第一、二兩個參數(shù)分別為cookie項的名稱和值。如果想為其設(shè)置一個過期時間,那么就需要設(shè)置第三個參數(shù),這里需要通過getExpDate()獲得一個正確格式的參數(shù)。
最后,使用deleteCookie()來刪除一個已存在的cookie項,實際上是通過讓該項過期。
cookie將數(shù)據(jù)保存在客戶端。頁面的腳本只能讀取所在域和服務(wù)器的cookie值,如果域內(nèi)有多個服務(wù)器,那么需要設(shè)置第五個參數(shù),以指定服務(wù)器。瀏覽器的容量一般限定為每服務(wù)器20個name/value對,每個cookie項不超過4000個字符,更現(xiàn)實點,單個cookie項應(yīng)少于2000字符,也就是說不要用cookie在客戶端保存大容量數(shù)據(jù)。
不同的瀏覽器保存cookie的方式也有所不同。IE為每個域的cookie建立一個文本文件,而Netscape則將所有的cookie存儲在同一個文本文件中。
注意:cookie存放在客戶端,所以會受到瀏覽器設(shè)置的影響,比如用戶可能會禁用cookie。要檢測瀏覽器是否支持cookie,使用屬性navigator.cookieEnabled來判斷。
您可能感興趣的文章:
- javascript實現(xiàn)操作cookie實現(xiàn)的可記憶菜單
- javascript操作cookie_獲取與修改代碼
- javascript 操作cookies及正確使用cookies的屬性
- JavaScript 對Cookie 操作的封裝小結(jié)
- Javascript Cookie讀寫刪除操作的函數(shù)
- javascript操作cookie的文章(設(shè)置,刪除cookies)
- javascript cookies操作集合
- javascript cookie操作類的實現(xiàn)代碼小結(jié)附使用方法
- Javascript操作cookie的函數(shù)代碼
- 淺析javascript操作 cookie對象
- 基于javascript的COOkie的操作實現(xiàn)只能點一次
- JavaScript中Cookie操作實例
- JavaScript操作Cookie詳解
- javascript操作Cookie(設(shè)置、讀取、刪除)方法詳解
相關(guān)文章
JS設(shè)置手機(jī)驗證碼60s等待實現(xiàn)代碼
本文給大家分享JS設(shè)置手機(jī)驗證碼60s等待實現(xiàn)代碼,需要的朋友參考下吧2017-06-06javascript中的關(guān)于類型轉(zhuǎn)換的性能優(yōu)化
類型轉(zhuǎn)換是大家常犯的錯誤,因為JavaScript是動態(tài)類型語言,你不能指定變量的類型。2010-12-12JavaScript實現(xiàn)函數(shù)緩存及應(yīng)用場景
在JavaScript中,可以通過函數(shù)緩存來提高函數(shù)的執(zhí)行效率,本文就來介紹一下JavaScript實現(xiàn)函數(shù)緩存及應(yīng)用場景,具有一定的參考價值,感興趣的可以了解一下2024-01-01javascript導(dǎo)出csv文件(excel)的方法示例
這篇文章主要給大家介紹了關(guān)于javascript導(dǎo)出csv文件(excel)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用javascript具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08ES2020讓代碼更優(yōu)美的運算符 (?.) (??)
這篇文章主要介紹了ES2020讓代碼更優(yōu)美的運算符 (?.) (??),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01