2017年8月29日 星期二

[JavaScript] 設定與取得Cookie值

轉載至:https://blog.aidec.tw/post/javascript-set-get-cookie

設定cookie

function setCookie(cookieName, cookieValue, exdays) {
  if (document.cookie.indexOf(cookieName) >= 0) {
    var expD = new Date();
    expD.setTime(expD.getTime() + (-1*24*60*60*1000));
    var uexpires = "expires="+expD.toUTCString();
    document.cookie = cookieName + "=" + cookieValue + "; " + uexpires; 
  
  var d = new Date();
  d.setTime(d.getTime() + (exdays*24*60*60*1000));
  var expires = "expires="+d.toUTCString();
  document.cookie = cookieName + "=" + cookieValue + "; " + expires;  
}

使用方法:

setCookie('自訂名稱','cookie值','天數');

舉例:

setCookie('myName','aidec','365');
將會設定一個名為myName的cookie,其cookie值為aidec,生命週期為365天
註:若已經有設定相同名稱的cookie值,此function將會自動覆蓋掉舊的值。

代碼說明:

此部分解說此函數原理,方便讓人自行修改。
/*第一段*/
//判斷是否已經有相同的cookie值。有的話,使舊的cookie過期
if (document.cookie.indexOf(cookieName) >= 0) {
    var expD = new Date();
    expD.setTime(expD.getTime() + (-1*24*60*60*1000));
    var uexpires = "expires="+expD.toUTCString();
    document.cookie = cookieName + "=" + cookieValue + "; " + uexpires; 
}
/*第二段*/
//設定cookie值
  var d = new Date();
  //可以自行修改此段,將過期週期設為符合需求的格式
  d.setTime(d.getTime() + (exdays*24*60*60*1000));
  var expires = "expires="+d.toUTCString();
  document.cookie = cookieName + "=" + cookieValue + "; " + expires;

讀取cookie

function getCookie(cookieName) {
  var name = cookieName + "=";
  var ca = document.cookie.split(';');
  for(var i=0; i<ca.length; i++) {
      var c = ca[i];
      while (c.charAt(0)==' ') c = c.substring(1);
      if (c.indexOf(name) == 0) return c.substring(name.length,c.length);
  }
  return "";
}

使用方法

getCookie('自訂的cookie名稱');

舉例:

以剛剛我們設定名為myName的cookie為範例
getCookie('myName'); //可得到 aidec
這樣就簡單完成用javascript設定和讀取cookie值了~~若假如想要能移除某項cookie值的話,我們可以提取setCookie當中的第一段在寫成另一個function來用,這樣就可以達成刪除某一cookie啦

沒有留言:

張貼留言