Cookies
定義:讓網站伺服器把少量資料儲存到客戶端的硬碟或記憶體,從客戶端的硬碟讀取資料的一種技術;
下載與引入:jquery.cookie.js基於jquery;先引入jquery,再引入:jquery.cookie.js;
下載:http://plugins.jquery.com/cookie/
<script type="text/javascript" src="js/jquery.min.js"></script> <script type="text/javascript" src="js/jquery.cookie.js"></script>
1.新增一個”會話cookie”
$.cookie(`the_cookie`, `the_value`);
這裡沒有指明 cookie有效時間,所建立的cookie有效期預設到使用者關閉瀏覽器為止,所以被稱為 “會話cookie(session cookie)”。
2.建立一個cookie並設定有效時間為 7天
$.cookie(`the_cookie`, `the_value`, { expires: 7 });
這裡指明瞭cookie有效時間,所建立的cookie被稱為“持久 cookie (persistent cookie)”。注意單位是:天;
3.建立一個cookie並設定 cookie的有效路徑
$.cookie(`the_cookie`, `the_value`, { expires: 7, path: `/` });
在預設情況下,只有設定 cookie的網頁才能讀取該 cookie。如果想讓一個頁面讀取另一個頁面設定的cookie,必須設定cookie的路徑。cookie的路徑用於設定能夠讀取 cookie的頂級目錄。將這個路徑設定為網站的根目錄,可以讓所有網頁都能互相讀取 cookie (一般不要這樣設定,防止出現衝突)。
4.讀取cookie
$.cookie(`the_cookie`);
5.刪除cookie
.cookie(`the_cookie`, null); //通過傳遞null作為cookie的值即可
6.可選引數
$.cookie(`the_cookie`,`the_value`,{ expires:7, path:`/`, domain:`jquery.com`, secure:true })
expires:(Number|Date)有效期;設定一個整數時,單位是天;也可以設定一個日期物件作為Cookie的過期日期;
path:(String)建立該Cookie的頁面路徑;
domain:(String)建立該Cookie的頁面域名;
secure:(Booblean)如果設為true,那麼此Cookie的傳輸會要求一個安全協議,例如:HTTPS;
程式碼示例:
<!doctype html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>無標題文件</title> <script src="jquery-1.8.3.min.js"></script> <script src="jquery.cookie.js"></script> <script src="jquery.base64.js"></script> <script language="javascript" type="text/javascript"> function setCookie(){ //設定cookie var loginCode = $("#login_code").val(); //獲取使用者名稱資訊 var pwd = $("#login_password").val(); //獲取登陸密碼資訊 var checked = $("[name=`checkbox`]:checked");//獲取“是否記住密碼”核取方塊 if(checked){ //判斷是否選中了“記住密碼”核取方塊 $.cookie("login_code",loginCode);//呼叫jquery.cookie.js中的方法設定cookie中的使用者名稱 $.cookie("pwd",$.base64.encode(pwd));//呼叫jquery.cookie.js中的方法設定cookie中的登陸密碼,並使用base64(jquery.base64.js)進行加密 }else{ $.cookie("pwd", null); } } function getCookie(){ //獲取cookie var loginCode = $.cookie("login_code"); //獲取cookie中的使用者名稱 var pwd = $.cookie("pwd"); //獲取cookie中的登陸密碼 if(pwd){//密碼存在的話把“記住使用者名稱和密碼”核取方塊勾選住 $("[name=`checkbox`]").attr("checked","true"); } if(loginCode){//使用者名稱存在的話把使用者名稱填充到使用者名稱文字框 $("#login_code").val(loginCode); } if(pwd){//密碼存在的話把密碼填充到密碼文字框 $("#login_password").val($.base64.decode(pwd)); } } function login(){ var userName = $(`#login_code`).value; if(userName == ``){ alert("請輸入使用者名稱。"); return; } var userPass = $(`#login_password`).value; if(userPass == ``){ alert("請輸入密碼。"); return; } //判斷是否選中核取方塊,如果選中,新增cookie if($("[name=`checkbox`]").attr("checked","true")){ //新增cookie setCookie(); alert("記住密碼登入。"); window.location = "http://www.baidu.com"; }else{ alert("不記密碼登入。"); window.location = "http://www.baidu.com"; } } </script> </head> <body onload="getCookie();"> <center> <table width="400px" height="180px" cellpadding="0" cellspacing="0" border="1" style="margin-top:100px;"> <tr> <td align="center" colspan="2">歡迎登入</td> </tr> <tr> <td align="right"> <label>使用者名稱:</label> </td> <td align="left"> <input type="text" id="login_code" name="login_code" style="width:160px; margin-left:10px;" /> </td> </tr> <tr> <td align="right"> <label>密 碼:</label> </td> <td align="left"> <input type="password" id="login_password" name="login_password" style="width:160px; margin-left:10px;" /> </td> </tr> <tr> <td align="center" colspan="2"> <span style="font-size:12px; color:blue; vertical-align:middle;">是否記住密碼</span> <input type="checkbox" style="vertical-align:middle;" /> </td> </tr> <tr> <td align="center" colspan="2"> <input type="submit" id="subLogin" name="subLogin" value="登 錄" onclick="login();"/> </td> </tr> </table> </center> </body> </html>