青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

使用 Cookies

使用 Cookies

  我們已經知道,在 document 對象中有一個 cookie 屬性。但是 Cookie 又是什么?“某些 Web 站點在您的硬盤上用很小的文本文件存儲了一些信息,這些文件就稱為 Cookie。”—— MSIE 幫助。一般來說,Cookies 是 CGI 或類似,比 HTML 高級的文件、程序等創建的,但是 JavaScript 也提供了對 Cookies 的很全面的訪問權利。

  在繼續之前,我們先要學一學 Cookie 的基本知識

  每個 Cookie 都是這樣的:<cookie名>=<值>

  <cookie名>的限制與 JavaScript 的命名限制大同小異,少了“不能用 JavaScript 關鍵字”,多了“只能用可以用在 URL 編碼中的字符”。后者比較難懂,但是只要你只用字母和數字命名,就完全沒有問題了。<值>的要求也是“只能用可以用在 URL 編碼中的字符”。

  每個 Cookie 都有失效日期,一旦電腦的時鐘過了失效日期,這個 Cookie 就會被刪掉。我們不能直接刪掉一個 Cookie,但是可以用設定失效日期早于現在時刻的方法來間接刪掉它。

  每個網頁,或者說每個站點,都有它自己的 Cookies,這些 Cookies 只能由這個站點下的網頁來訪問,來自其他站點或同一站點下未經授權的區域的網頁,是不能訪問的。每一“組”Cookies 有規定的總大小(大約 2KB 每“組”),一超過最大總大小,則最早失效的 Cookie 先被刪除,來讓新的 Cookie“安家”。

  現在我們來學習使用 document.cookie 屬性

  如果直接使用 document.cookie 屬性,或者說,用某種方法,例如給變量賦值,來獲得 document.cookie 的值,我們就可以知道在現在的文檔中有多少個 Cookies,每個 Cookies 的名字,和它的值。例如,在某文檔中添加“document.write(document.cookie)”,結果顯示:

name=kevin; email=kevin@kevin.com; lastvisited=index.html

這意味著,文檔包含 3 個 Cookies:name, email 和 lastvisited,它們的值分別是 kevin, kevin@kevin.com 和 index.html。可以看到,兩個 Cookies 之間是用分號和空格隔開的,于是我們可以用 cookieString.split('; ') 方法得到每個 Cookie 分開的一個數組(先用 var cookieString = document.cookie)。

  設定一個 Cookie 的方法是對 document.cookie 賦值。與其它情況下的賦值不同,向 document.cookie 賦值不會刪除掉原有的 Cookies,而只會增添 Cookies 或更改原有 Cookie。賦值的格式:

document.cookie = 'cookieName=' + escape('cookieValue')
???? + ';expires=' + expirationDateObj.toGMTString();

是不是看到頭暈了呢?以上不是粗體字的地方是要照抄不誤的,粗體字是要按實際情況做出改動的。cookieName 表示 Cookie 的名稱,cookieValue 表示 Cookie 的值,expirationDateObj 表示儲存著失效日期的日期對象名,如果不需要指定失效日期,則不需要第二行。不指定失效日期,則瀏覽器默認是在關閉瀏覽器(也就是關閉所有窗口)之后過期。

  看到了上面的一些下劃線了么?這些是應該注意的地方。
  首先 escape() 方法:為什么一定要用?因為 Cookie 的值的要求是“只能用可以用在 URL 編碼中的字符”。我們知道“escape()”方法是把字符串按 URL 編碼方法來編碼的,那我們只需要用一個“escape()”方法來處理輸出到 Cookie 的值,用“unescape()”來處理從 Cookie 接收過來的值就萬無一失了。而且這兩個方法的最常用途就是處理 Cookies。其實設定一個 Cookie 只是“document.cookie = 'cookieName=cookieValue'”這么簡單,但是為了避免在 cookieValue 中出現 URL 里不準出現的字符,還是用一個 escape() 好。
  然后“expires”前面的分號:注意到就行了。是分號而不是其他。
  最后 toGMTString() 方法:設定 Cookie 的時效日期都是用 GMT 格式的時間的,其它格式的時間是沒有作用的。

  現在我們來實戰一下。設定一個“name=rose”的 Cookie,在 3 個月后過期。

var expires = new Date();
expires.setTime(expires.getTime() + 3 * 30 * 24 * 60 * 60 * 1000);
/*?? 三個月 x 一個月當作 30 天 x 一天 24 小時
?? x 一小時 60 分 x 一分 60 秒 x 一秒 1000 毫秒 */
document.cookie = 'name=rose;expires=' + expires.toGMTString();

為什么沒有用 escape() 方法?這是因為我們知道 rose 是一個合法的 URL 編碼字符串,也就是說,'rose' == escape('rose')。一般來說,如果設定 Cookie 時不用 escape(),那獲取 Cookie 時也不用 unescape()。

  再來一次:編寫一個函數,作用是查找指定 Cookie 的值。

function getCookie(cookieName) {
? var cookieString = document.cookie;
? var start = cookieString.indexOf(cookieName + '=');
? // 加上等號的原因是避免在某些 Cookie 的值里有
? // 與 cookieName 一樣的字符串。
? if (start == -1) // 找不到
??? return null;
? start += cookieName.length + 1;
? var end = cookieString.indexOf(';', start);
? if (end == -1) return unescape(cookieString.substring(start));
? return unescape(cookieString.substring(start, end));
}

這個函數用到了字符串對象的一些方法,如果你不記得了(你是不是這般沒記性啊),請快去查查。這個函數所有的 if 語句都沒有帶上 else,這是因為如果條件成立,程序運行的都是 return 語句,在函數里碰上 return,就會終止運行,所以不加 else 也沒問題。該函數在找到 Cookie 時,就會返回 Cookie 的值,否則返回“null”。

  現在我們要刪除剛才設定的 name=rose Cookie。

var expires = new Date();
expires.setTime(expires.getTime() - 1);
document.cookie = 'name=rose;expires=' + expires.toGMTString();

可以看到,只需要把失效日期改成比現在日期早一點(這里是早 1 毫秒),再用同樣的方法設定 Cookie,就可以刪掉 Cookie 了。

posted on 2007-03-19 20:56 PeakGao 閱讀(302) 評論(0)  編輯 收藏 引用 所屬分類: Javascript

<2007年4月>
25262728293031
1234567
891011121314
15161718192021
22232425262728
293012345

導航

統計

常用鏈接

留言簿(9)

隨筆分類(67)

隨筆檔案(65)

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            美日韩精品视频免费看| 国产毛片一区二区| 亚洲色诱最新| 亚洲精品一区二区三区樱花 | 一本久道久久久| 99精品国产在热久久婷婷| 日韩午夜在线播放| 亚洲女优在线| 美女诱惑一区| 欧美性理论片在线观看片免费| 国产精品国产三级国产| 国产一区在线视频| 亚洲人精品午夜在线观看| 亚洲夜间福利| 可以看av的网站久久看| 亚洲欧洲一区二区三区在线观看| 亚洲国产精品综合| 亚洲欧美国产一区二区三区| 久久夜色精品国产欧美乱| 欧美激情第9页| 国产欧美一区二区三区沐欲 | 午夜亚洲激情| 欧美一区久久| 欧美国产日韩在线| 国产精品一区二区在线| 最新高清无码专区| 久久成人免费电影| 亚洲国产精品尤物yw在线观看| 亚洲一区欧美一区| 欧美激情精品久久久久久免费印度| 国产精品久久久久久久久久ktv | 久久久久久自在自线| 欧美第一黄网免费网站| 亚洲天堂视频在线观看| 免费中文字幕日韩欧美| 久久中文久久字幕| 亚洲午夜在线观看| 欧美女主播在线| 亚洲第一网站| 久久精品最新地址| 亚洲自啪免费| 欧美亚洲第一区| 亚洲三级免费观看| 欧美不卡视频一区发布| 午夜日韩激情| 国产乱人伦精品一区二区| 中文在线一区| 亚洲精品午夜精品| 欧美精品久久天天躁| 亚洲国产成人精品久久| 国产精品乱码人人做人人爱| av成人免费在线观看| 欧美激情女人20p| 久久亚洲二区| 在线成人免费观看| 久久免费精品视频| 久久国产精品黑丝| 国内精品免费午夜毛片| 久久久九九九九| 欧美资源在线| 一区二区亚洲| 欧美国产一区二区三区激情无套| 久久深夜福利免费观看| 亚洲盗摄视频| 欧美jizz19性欧美| 蘑菇福利视频一区播放| 91久久在线播放| 亚洲欧洲视频在线| 欧美日韩一二三区| 亚洲欧美激情一区二区| 亚洲欧美区自拍先锋| 国产女精品视频网站免费| 久久精品99| 久久网站免费| 夜夜精品视频一区二区| 一区二区三区成人精品| 欧美极品一区| 亚洲一区网站| 国产日韩av高清| 国产日韩欧美一区| 美女日韩在线中文字幕| 欧美大片在线看| 亚洲自拍偷拍麻豆| 久久精品国产一区二区三区| 亚洲人成毛片在线播放女女| 亚洲少妇最新在线视频| 国产欧美在线观看一区| 模特精品裸拍一区| 欧美日韩精品久久| 久久天堂精品| 欧美日韩三级一区二区| 欧美在线视频a| 欧美国产成人精品| 久久福利精品| 欧美激情视频一区二区三区免费| 欧美一区二区三区在线视频| 麻豆av一区二区三区| 亚洲视频国产视频| 看欧美日韩国产| 午夜精品视频一区| 欧美精品一区二区三区很污很色的| 午夜在线一区| 欧美激情久久久| 久久久久一区二区| 国产精品porn| 亚洲国产欧美日韩另类综合| 夜夜爽夜夜爽精品视频| 影音先锋亚洲视频| 亚洲一区免费网站| 一区二区三区免费看| 久久美女艺术照精彩视频福利播放| 亚洲特色特黄| 欧美激情第9页| 欧美成人69av| 黑人操亚洲美女惩罚| 亚洲午夜激情网站| 一本色道久久综合狠狠躁篇的优点| 欧美一区二区三区视频| 亚洲一区在线观看视频| 欧美极品一区| 亚洲成人直播| 亚洲大胆美女视频| 久久久噜噜噜久噜久久| 久久精品免费| 国产欧美日韩在线观看| 亚洲视频在线看| 亚洲私人黄色宅男| 欧美日韩国内自拍| 最新69国产成人精品视频免费| 在线观看视频一区二区欧美日韩| 欧美综合激情网| 久久麻豆一区二区| 国产一区二区三区观看| 亚洲你懂的在线视频| 香蕉久久夜色精品| 国产精品一级久久久| 亚洲一区日韩| 小处雏高清一区二区三区| 欧美性久久久| 亚洲欧美日韩成人| 久久成人这里只有精品| 国产一区二区精品| 久久综合久久美利坚合众国| 欧美日本三级| 欧美成人精品在线播放| 黑人一区二区三区四区五区| 亚洲综合色自拍一区| 欧美一区二区三区免费观看视频| 国产精品久久久久久影院8一贰佰| 99人久久精品视频最新地址| 亚洲图片在区色| 国产精品日韩在线播放| 亚洲图片欧洲图片av| 蜜臀久久99精品久久久久久9 | 亚洲一区二区3| 香港成人在线视频| 精品av久久久久电影| 老色鬼久久亚洲一区二区| 亚洲国产一二三| 亚洲综合99| 一区二区在线视频观看| 欧美激情自拍| 亚洲欧美国产77777| 免播放器亚洲一区| 一区二区毛片| 国产一区在线播放| 欧美日本韩国一区二区三区| 亚洲欧美在线一区二区| 欧美激情一区二区久久久| 亚洲一区二区在线播放| 红桃视频国产精品| 欧美日韩午夜激情| 久久视频在线看| 亚洲小说欧美另类婷婷| 欧美成人黑人xx视频免费观看| 亚洲网站在线观看| 激情偷拍久久| 国产精品成人一区二区三区吃奶| 久久国产精品色婷婷| 一区二区91| 欧美高清视频www夜色资源网| 亚洲女性喷水在线观看一区| 一区精品久久| 国产精品毛片| 欧美三级不卡| 欧美成人a∨高清免费观看| 亚洲欧美中文日韩在线| 99伊人成综合| 亚洲成色精品| 久久综合伊人77777麻豆| 亚洲欧美国产视频| 日韩亚洲一区二区| 最新国产成人在线观看| 国产亚洲成av人在线观看导航| 欧美色综合天天久久综合精品| 老司机精品视频网站| 久久精品国产77777蜜臀 | 欧美在线91| 亚洲自拍偷拍视频| 亚洲午夜av|