javascript cookie用法基礎教程(概念,設定,讀取及刪除)_基礎知識

來源:互聯網
上載者:User

本文執行個體講述了javascript cookie用法。分享給大家供大家參考,具體如下:

一、什麼是 cookie?

cookie 就是頁面用來儲存資訊,比如自動登入、記住使用者名稱等等。

二、cookie 的特點

同個網站中所有的頁面共用一套 cookie

cookie 有數量、大小限制

cookie 有到期時間

三、如何使用 cookie?

通過 document.cookie 來寫入 cookie

<!DOCTYPE HTML><html lang="en-US"><head> <meta charset="UTF-8"> <title>cookie基礎</title></head><body></body></html><script type="text/javascript">document.cookie = 'username=abc';document.cookie = 'password=123';document.cookie = 'email=abcdef@123.com';</script>

開啟瀏覽器查看 cookie,可以發現新定義的 cookie 並不會將原來的覆蓋。

如果沒有設定到期時間,那麼關閉瀏覽器就會清空 cookie。如何設定到期時間呢?答案是:expires。一般我們會結合 Date 對象來使用。

var d = new Date();d.setTime(d.getTime() + 1 * 3600 * 1000);document.cookie = 'username=abc; expires=' + d.toGMTString();

我們可以通過Firefox瀏覽器看到,username 的到期時間是目前時間的 1 小時後。

最後對擷取 cookie 的方法進行封裝:

function setCookie(name,value,hours){  var d = new Date(); d.setTime(d.getTime() + hours * 3600 * 1000); document.cookie = name + '=' + value + '; expires=' + d.toGMTString();}

學會了如何設定 cookie,那麼該如何讀取 cookie 呢?

首先我們看下 cookie 裡的內容是什麼類型?

document.cookie = 'username=abc';document.cookie = 'password=123';document.cookie = 'email=abcdef@123.com';typeof document.cookie; //stringalert(document.cookie); //'username=abc; password=123; email=abcdef@123.com'

得到的是一串字串,需要注意的是,每個 ; 後面都有個空格。

那麼我們如何取到具體的數值呢?附上代碼:

function getCookie(name){  var arr = document.cookie.split('; '); for(var i = 0; i < arr.length; i++){ var temp = arr[i].split('='); if(temp[0] == name){  return temp[1]; } } return '';}

除了設定、擷取 cookie,我們還可以刪除 cookie。我們在網上經常看到有清除使用者名稱這樣的功能,其實就是用到了清除 cookie。

清除 cookie 其實很簡單,只要使到期時間為過去時間就可以了。

function removeCookie(name){ var d = new Date(); d.setTime(d.getTime() - 10000); document.cookie = name + '=1; expires=' + d.toGMTString();}

最後我們將設定、擷取、清除 cookie 封裝成一個 cookie.js

function setCookie(name,value,hours){  var d = new Date(); d.setTime(d.getTime() + hours * 3600 * 1000); document.cookie = name + '=' + value + '; expires=' + d.toGMTString();}function getCookie(name){  var arr = document.cookie.split('; '); for(var i = 0; i < arr.length; i++){ var temp = arr[i].split('='); if(temp[0] == name){  return temp[1]; } } return '';}function removeCookie(name){ var d = new Date(); d.setTime(d.getTime() - 10000); document.cookie = name + '=1; expires=' + d.toGMTString();}

附:這裡再補充一個關於cookie的基礎應用:javascript cookie記錄使用者名稱

更多關於JavaScript相關內容感興趣的讀者可查看本站專題:《JavaScript中json操作技巧總結》、《JavaScript切換特效與技巧總結》、《JavaScript尋找演算法技巧總結》、《JavaScript動畫特效與技巧匯總》、《JavaScript錯誤與調試技巧總結》、《JavaScript資料結構與演算法技巧總結》、《JavaScript遍曆演算法與技巧總結》及《JavaScript數學運算用法總結》

希望本文所述對大家JavaScript程式設計有所協助。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.