• <fieldset id="8imwq"><menu id="8imwq"></menu></fieldset>
  • <bdo id="8imwq"><input id="8imwq"></input></bdo>
    最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
    問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
    當前位置: 首頁 - 科技 - 知識百科 - 正文

    JavaScript的Cookies_基礎知識

    來源:懂視網(wǎng) 責編:小采 時間:2020-11-27 20:38:35
    文檔

    JavaScript的Cookies_基礎知識

    JavaScript的Cookies_基礎知識:使用 Cookies 我們已經(jīng)知道,在 document 對象中有一個 cookie 屬性。但是 Cookie 又是什么?某些 Web 站點在您的硬盤上用很小的文本文件存儲了一些信息,這些文件就稱為 Cookie。—— MSIE 幫助。一般來說,Cookies 是 CGI 或類似,比 H
    推薦度:
    導讀JavaScript的Cookies_基礎知識:使用 Cookies 我們已經(jīng)知道,在 document 對象中有一個 cookie 屬性。但是 Cookie 又是什么?某些 Web 站點在您的硬盤上用很小的文本文件存儲了一些信息,這些文件就稱為 Cookie。—— MSIE 幫助。一般來說,Cookies 是 CGI 或類似,比 H

    使用 Cookies  我們已經(jīng)知道,在 document 對象中有一個 cookie 屬性。但是 Cookie 又是什么?“某些 Web 站點在您的硬盤上用很小的文本文件存儲了一些信息,這些文件就稱為 Cookie。”—— MSIE 幫助。一般來說,Cookies 是 CGI 或類似,比 HTML 高級的文件、程序等創(chuàng)建的,但是 JavaScript 也提供了對 Cookies 的很全面的訪問權利。
      在繼續(xù)之前,我們先要學一學 Cookie 的基本知識。
      每個 Cookie 都是這樣的:=<值>
      的限制與 JavaScript 的命名限制大同小異,少了“不能用 JavaScript 關鍵字”,多了“只能用可以用在 URL 編碼中的字符”。后者比較難懂,但是只要你只用字母和數(shù)字命名,就完全沒有問題了。<值>的要求也是“只能用可以用在 URL 編碼中的字符”。
      每個 Cookie 都有失效日期,一旦電腦的時鐘過了失效日期,這個 Cookie 就會被刪掉。我們不能直接刪掉一個 Cookie,但是可以用設定失效日期早于現(xiàn)在時刻的方法來間接刪掉它。
      每個網(wǎng)頁,或者說每個站點,都有它自己的 Cookies,這些 Cookies 只能由這個站點下的網(wǎng)頁來訪問,來自其他站點或同一站點下未經(jīng)授權的區(qū)域的網(wǎng)頁,是不能訪問的。每一“組”Cookies 有規(guī)定的總大小(大約 2KB 每“組”),一超過最大總大小,則最早失效的 Cookie 先被刪除,來讓新的 Cookie“安家”。
      現(xiàn)在我們來學習使用 document.cookie 屬性。
      如果直接使用 document.cookie 屬性,或者說,用某種方法,例如給變量賦值,來獲得 document.cookie 的值,我們就可以知道在現(xiàn)在的文檔中有多少個 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 分開的一個數(shù)組(先用 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 中出現(xiàn) URL 里不準出現(xiàn)的字符,還是用一個 escape() 好。
      然后“expires”前面的分號:注意到就行了。是分號而不是其他。
      最后 toGMTString() 方法:設定 Cookie 的時效日期都是用 GMT 格式的時間的,其它格式的時間是沒有作用的。
      現(xiàn)在我們來實戰(zhàn)一下。設定一個“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()。

      再來一次:編寫一個函數(shù),作用是查找指定 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));
    }

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

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

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

    聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文檔

    JavaScript的Cookies_基礎知識

    JavaScript的Cookies_基礎知識:使用 Cookies 我們已經(jīng)知道,在 document 對象中有一個 cookie 屬性。但是 Cookie 又是什么?某些 Web 站點在您的硬盤上用很小的文本文件存儲了一些信息,這些文件就稱為 Cookie。—— MSIE 幫助。一般來說,Cookies 是 CGI 或類似,比 H
    推薦度:
    標簽: cookie js 基本
    • 熱門焦點

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: 精品视频在线免费观看| 精品国产综合区久久久久久| 国产成人毛片亚洲精品| 无码人妻精品一区二区三| 国产精品亚洲综合一区| 55夜色66夜色国产精品视频| 亚洲欧美日韩国产精品| 国产精品手机在线观看你懂的| 99国产精品国产精品九九| 尤物国精品午夜福利视频| 99久久精品九九亚洲精品| 91精品一区国产高清在线| 亚洲av日韩精品久久久久久a | 久久99精品久久久久久久不卡| 国产亚洲精品自在线观看| 最新亚洲精品国自产在线观看| 国产麻豆精品一区二区三区v视界 国产麻豆一精品一AV一免费 | 亚洲精品无码不卡在线播HE| 久久久久无码精品国产app| 99久久精品无码一区二区毛片| 国产精品夜色一区二区三区| 精品国产一级在线观看| 亚洲国产精品无码av| 亚洲精品中文字幕无码蜜桃| 亚洲天堂久久精品| 91久久精品91久久性色| 欧美久久久久久午夜精品| 国产精品爽爽ⅴa在线观看| 2021国产精品视频| 无码人妻精品一区二区三区东京热 | 人妻少妇精品久久| 亚洲国产精品福利片在线观看| 亚洲精品综合一二三区在线| 国产精品va久久久久久久| 欧美精品亚洲人成在线观看| 99久久精品国产一区二区| 亚洲AV永久无码精品一百度影院| 国产精品丝袜一区二区三区 | 国产成人精品一区二区秒拍| 亚洲中文久久精品无码| 自拍中文精品无码|