天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

JavaScript的Cookies

使用 Cookies  我們已經(jīng)知道,在 document 對(duì)象中有一個(gè) cookie 屬性。但是 Cookie 又是什么?“某些 Web 站點(diǎn)在您的硬盤上用很小的文本文件存儲(chǔ)了一些信息,這些文件就稱為 Cookie。”―― MSIE 幫助。一般來(lái)說(shuō),Cookies 是 CGI 或類似,比 HTML 高級(jí)的文件、程序等創(chuàng)建的,但是 JavaScript 也提供了對(duì) Cookies 的很全面的訪問(wèn)權(quán)利。
  在繼續(xù)之前,我們先要學(xué)一學(xué) Cookie 的基本知識(shí)。
  每個(gè) Cookie 都是這樣的:<cookie名>=<值>
  <cookie名>的限制與 JavaScript 的命名限制大同小異,少了“不能用 JavaScript 關(guān)鍵字”,多了“只能用可以用在 URL 編碼中的字符”。后者比較難懂,但是只要你只用字母和數(shù)字命名,就完全沒(méi)有問(wèn)題了。<值>的要求也是“只能用可以用在 URL 編碼中的字符”。
  每個(gè) Cookie 都有失效日期,一旦電腦的時(shí)鐘過(guò)了失效日期,這個(gè) Cookie 就會(huì)被刪掉。我們不能直接刪掉一個(gè) Cookie,但是可以用設(shè)定失效日期早于現(xiàn)在時(shí)刻的方法來(lái)間接刪掉它。
  每個(gè)網(wǎng)頁(yè),或者說(shuō)每個(gè)站點(diǎn),都有它自己的 Cookies,這些 Cookies 只能由這個(gè)站點(diǎn)下的網(wǎng)頁(yè)來(lái)訪問(wèn),來(lái)自其他站點(diǎn)或同一站點(diǎn)下未經(jīng)授權(quán)的區(qū)域的網(wǎng)頁(yè),是不能訪問(wèn)的。每一“組”Cookies 有規(guī)定的總大小(大約 2KB 每“組”),一超過(guò)最大總大小,則最早失效的 Cookie 先被刪除,來(lái)讓新的 Cookie“安家”。
  現(xiàn)在我們來(lái)學(xué)習(xí)使用 document.cookie 屬性。
  如果直接使用 document.cookie 屬性,或者說(shuō),用某種方法,例如給變量賦值,來(lái)獲得 document.cookie 的值,我們就可以知道在現(xiàn)在的文檔中有多少個(gè) Cookies,每個(gè) Cookies 的名字,和它的值。例如,在某文檔中添加“document.write(document.cookie)”,結(jié)果顯示:

name=kevin; [email protected]; lastvisited=index.html

這意味著,文檔包含 3 個(gè) Cookies:name, email 和 lastvisited,它們的值分別是 kevin, [email protected] 和 index.html。可以看到,兩個(gè) Cookies 之間是用分號(hào)和空格隔開(kāi)的,于是我們可以用 cookieString.split('; ') 方法得到每個(gè) Cookie 分開(kāi)的一個(gè)數(shù)組(先用 var cookieString = document.cookie)。
  設(shè)定一個(gè) Cookie 的方法是對(duì) document.cookie 賦值。與其它情況下的賦值不同,向 document.cookie 賦值不會(huì)刪除掉原有的 Cookies,而只會(huì)增添 Cookies 或更改原有 Cookie。賦值的格式:

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

是不是看到頭暈了呢?以上不是粗體字的地方是要照抄不誤的,粗體字是要按實(shí)際情況做出改動(dòng)的。cookieName 表示 Cookie 的名稱,cookieValue 表示 Cookie 的值,expirationDateObj 表示儲(chǔ)存著失效日期的日期對(duì)象名,如果不需要指定失效日期,則不需要第二行。不指定失效日期,則瀏覽器默認(rèn)是在關(guān)閉瀏覽器(也就是關(guān)閉所有窗口)之后過(guò)期。
  看到了上面的一些下劃線了么?這些是應(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ò)期。


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

為什么沒(méi)有用 escape() 方法?這是因?yàn)槲覀冎?nbsp;rose 是一個(gè)合法的 URL 編碼字符串,也就是說(shuō),'rose' == escape('rose')。一般來(lái)說(shuō),如果設(shè)定 Cookie 時(shí)不用 escape(),那獲取 Cookie 時(shí)也不用 unescape()。

  再來(lái)一次:編寫一個(gè)函數(shù),作用是查找指定 Cookie 的值。

function getCookie(cookieName) {
  var cookieString = document.cookie;
  var start = cookieString.indexOf(cookieName + '=');
  // 加上等號(hào)的原因是避免在某些 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));
}

這個(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”。
  現(xiàn)在我們要?jiǎng)h除剛才設(shè)定的 name=rose Cookie。

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

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

JavaScript技術(shù)JavaScript的Cookies,轉(zhuǎn)載需保留來(lái)源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 久久蜜视频 | x8国产精品视频 | 抽插妇女疯狂视频 | 性插图动态图无遮挡 | 高清一区二区亚洲欧美日韩 | 我的美女奴隶 | 九九免费的视频 | 国产精品婷婷久青青原 | 亚洲AV无码久久流水呻蜜桃久色 | 日本老妇一级特黄aa大片 | 高H各种PLAY全肉NP | 国产短视频精品区 | 午夜宅宅伦电影网 | 精品久久久久久无码人妻国产馆 | 乌克兰内射私拍 | 成品片a免人看免费 | 97一期涩涩97片久久久久久久 | 3D漫画H精品啪啪无码 | 男人边吃奶边挵进去呻吟漫画 | 成年私人影院网站在线看 | 色翁荡息又大又硬又粗又爽电影 | 人人干人人看 | 果冻传媒 在线播放观看 | www色视频在线观看 WWW色视频片内射 | 九九热视频这里只有精 | 免费播放美女一级毛片 | 白人大战34厘米黑人BD | 羞羞答答dc视频 | 久久人妻AV一区二区软件 | 国产高清免费视频免费观看 | 午夜AV国产欧美亚洲高清在线 | 婷婷综合亚洲爱久久 | 欧美性受xxxx狂喷水 | 国产精品免费观看视频 | 迅雷哥在线观看高清 | 国产亚洲精品AV片在线观看播放 | 电影 qvod| 久久性生大片免费观看性 | xxxx18动漫 | 国产互换后人妻的疯狂VIDEO | 嫩草影院永久在线一二三四 |