一、jQuery.Cookie.js外掛程式是一個輕量級的Cookie管理外掛程式。
特別提醒,今日發現一個特別的錯誤,google瀏覽器提示:has no method $.cookie。火狐瀏覽器提示:$.cookie is not a function;調試了半天,終於找到原因,如果同一個頁面兩次或多次引入jQuery插件就會報此錯誤。
使用方法:
1、引入jQuery與jQuery.Cookie.js插件。
<script src="jQuery.1.8.3.js" type="text/javascript"></script> <script src="jquery.cookie.js" type="text/javascript"></script>
2、函數。
語法:$.cookie(名稱,值,[option])
(1)讀取cookie值
ookie(cookieName) ookiepookieName ookieName pookieName)。
示例:$.cookie("username"); 读取保存在cookie中名为的username的值。
(2)寫入設定Cookie值:
$.cookie(cookieName,cookieValue); $.cookie(cookieName,cookieValue);應對應的名稱對應的名稱。
示例: $.cookie("username","admin"); 将值"admin"写入cookie名为username的cookie中。 $.cookie("username",NULL); 销毁名称为username的cookie
(3) [option]參數說明:
expires:
expires: 天數日期,可以是整數日期。 這個地方也要注意,如果不設定這個東西,瀏覽器關閉之後此cookie就失效了
path: cookie值保存的路徑,預設與建立頁路徑一致。
domin: cookie網域屬性,預設與建立頁網域名稱相同。 這個地方要相當注意,跨域的概念,如果要主域名二級域名有效則要設定 ".xxx.com"
secrue: 一個布爾值,傳輸是否需要一個安全協議時,是否需要一個安全協議。
示例: $.cookie("like", $(":radio[checked]").val(), { path: "/", expiress: 7 })
一個完整設定與讀取cookie的頁面代碼:
<html xmlns="http://www.w3.org/1999/xhtml"> <head> <title>jQuery学习2</title> <script src="jQuery.1.8.3.js" type="text/javascript"></script> <script src="jquery.cookie.js" type="text/javascript"></script> <script type="text/javascript"> $(function () { $("#username").val($.cookie("username")); if ($.cookie("like") == "刘德华") { $(":radio[value='刘德华']").attr("checked", 'checked') } else { $(":radio[value='张学友']").attr("checked", 'checked') } $(":button").click(function () { $.cookie("username", $("#username").val(), { path: "/", expires: 7 }) $.cookie("like", $(":radio[checked]").val(), { path: "/", expiress: 7 }) }) }) </script> </head> <body> <p><input type="text" id="username" value="" /></p> <p> <input type="radio" name="like" value="刘德华" />刘德华 <input type="radio" name="like" value="张学友" />张学友 </p> <p><input type="button" value="保存" /></p> </body> </html>
才能
cookie本質上是一個文字,因此只存入字串之後,才能存入物件,因此只存入字串之後,只能存入文字,因此只存入字串之後,才能存入物件,因此只存入字串之後,只能存入文字,因此只存入字串之後,才能存入物件序列可以存入文字,因此只存入字串之後,才能存入物件,因此只存入字串之後,只能存入文字,因此只存入字串之後,才能存入物件順序cookie,而取的時候要反序列才又能得到物件。
$(function () { if ($.cookie("o") == null) { var o = { name: "张三", age: 24 }; var str = JSON.stringify(o); //对序列化成字符串然后存入cookie $.cookie("o", str, { expires:7 //设置时间,如果此处留空,则浏览器关闭此cookie就失效。 }); alert("cookie为空"); } else { var str1 = $.cookie("o"); var o1 = JSON.parse(str1); //字符反序列化成对象 alert(o1.name); //输反序列化出来的对象的姓名值 } })