咨詢電話:024-31891684

build網(wǎng)站制作 |
build網(wǎng)站制作當(dāng)前位置:首頁(yè)>主要服務(wù)>網(wǎng)站制作JavaScript的Cookies使用 Cookies 我們已經(jīng)知道,在 document 對(duì)象中有一個(gè) cookie 屬性。但是 Cookie 又是什么?“某些 Web 站點(diǎn)在您的硬盤(pán)上用很小的文本文件存儲(chǔ)了一些信息,這些文件就稱為 Cookie?!薄?nbsp;MSIE 幫助。一般來(lái)說(shuō),Cookies 是 CGI 或類似,比 HTML 高級(jí)的文件、程序等創(chuàng)建的,但是 JavaScript 也提供了對(duì) Cookies 的很全面的訪問(wèn)權(quán)利。 這意味著,文檔包含 3 個(gè) Cookies:name, email 和 lastvisited,它們的值分別是 kevin, kevin@kevin.com 和 index.html??梢钥吹?,兩個(gè) Cookies 之間是用分號(hào)和空格隔開(kāi)的,于是我們可以用 cookieString.split('; ') 方法得到每個(gè) Cookie 分開(kāi)的一個(gè)數(shù)組(先用 var cookieString = document.cookie)。name=kevin; email=kevin@kevin.com; lastvisited=index.html 設(shè)定一個(gè) Cookie 的方法是對(duì) document.cookie 賦值。與其它情況下的賦值不同,向 document.cookie 賦值不會(huì)刪除掉原有的 Cookies,而只會(huì)增添 Cookies 或更改原有 Cookie。賦值的格式: 是不是看到頭暈了呢?以上不是粗體字的地方是要照抄不誤的,粗體字是要按實(shí)際情況做出改動(dòng)的。cookieName 表示 Cookie 的名稱,cookieValue 表示 Cookie 的值,expirationDateObj 表示儲(chǔ)存著失效日期的日期對(duì)象名,如果不需要指定失效日期,則不需要第二行。不指定失效日期,則瀏覽器默認(rèn)是在關(guān)閉瀏覽器(也就是關(guān)閉所有窗口)之后過(guò)期。document.cookie = 'cookieName=' + escape('cookieValue') 看到了上面的一些下劃線了么?這些是應(yīng)該注意的地方。 首先 escape() 方法:為什么一定要用?因?yàn)?nbsp;Cookie 的值的要求是“只能用可以用在 URL 編碼中的字符”。我們知道“escape()”方法是把字符串按 URL 編碼方法來(lái)編碼的,那我們只需要用一個(gè)“escape()”方法來(lái)處理輸出到 Cookie 的值,用“unescape()”來(lái)處理從 Cookie 接收過(guò)來(lái)的值就萬(wàn)無(wú)一失了。而且這兩個(gè)方法的最常用途就是處理 Cookies。其實(shí)設(shè)定一個(gè) Cookie 只是“document.cookie = 'cookieName=cookieValue'”這么簡(jiǎn)單,但是為了避免在 cookieValue 中出現(xiàn) URL 里不準(zhǔn)出現(xiàn)的字符,還是用一個(gè) escape() 好。 然后“expires”前面的分號(hào):注意到就行了。是分號(hào)而不是其他。 最后 toGMTString() 方法:設(shè)定 Cookie 的時(shí)效日期都是用 GMT 格式的時(shí)間的,其它格式的時(shí)間是沒(méi)有作用的。 現(xiàn)在我們來(lái)實(shí)戰(zhàn)一下。設(shè)定一個(gè)“name=rose”的 Cookie,在 3 個(gè)月后過(guò)期。 再來(lái)一次:編寫(xiě)一個(gè)函數(shù),作用是查找指定 Cookie 的值。為什么沒(méi)有用 escape() 方法?這是因?yàn)槲覀冎?nbsp;rose 是一個(gè)合法的 URL 編碼字符串,也就是說(shuō),'rose' == escape('rose')。一般來(lái)說(shuō),如果設(shè)定 Cookie 時(shí)不用 escape(),那獲取 Cookie 時(shí)也不用 unescape()。 這個(gè)函數(shù)用到了字符串對(duì)象的一些方法,如果你不記得了(你是不是這般沒(méi)記性?。?,請(qǐng)快去查查。這個(gè)函數(shù)所有的 if 語(yǔ)句都沒(méi)有帶上 else,這是因?yàn)槿绻麠l件成立,程序運(yùn)行的都是 return 語(yǔ)句,在函數(shù)里碰上 return,就會(huì)終止運(yùn)行,所以不加 else 也沒(méi)問(wèn)題。該函數(shù)在找到 Cookie 時(shí),就會(huì)返回 Cookie 的值,否則返回“null”。function getCookie(cookieName) { 現(xiàn)在我們要?jiǎng)h除剛才設(shè)定的 name=rose Cookie。 可以看到,只需要把失效日期改成比現(xiàn)在日期早一點(diǎn)(這里是早 1 毫秒),再用同樣的方法設(shè)定 Cookie,就可以刪掉 Cookie 了。var expires = new Date();
網(wǎng)站動(dòng)態(tài)
|
易勢(shì)沈陽(yáng)建站專業(yè)機(jī)構(gòu),以DIV+CSS為主,js/jQuery為輔,制作利于優(yōu)化,頁(yè)面美觀的優(yōu)質(zhì)網(wǎng)站!

網(wǎng)絡(luò)策劃公司|新浪官方微博|大連網(wǎng)站建設(shè)
沈陽(yáng)易勢(shì)科技有限公司 網(wǎng)站制作網(wǎng)絡(luò)營(yíng)銷公司 © 2011 , All rights reserved. 公司地址:沈陽(yáng)市鐵西區(qū)貴和街道建設(shè)中路15號(hào)淺草綠閣商務(wù)樓402室沈陽(yáng)做網(wǎng)站 沈陽(yáng)建站
遼B2-20150173-8