提示:Cookie 由若干个键/值对组成(例如 key1=value1;key2=value2
),一个 Cookie 最大可以存储 4kb 的数据,超过长度的 Cookie 将被忽略。您也可以在浏览器端禁用 Cookie,这样一些借助 Cookie 才能完成的操作将无法进行。另外,不要在 Cookie 中存储账号、密码等敏感信息。
document.cookie
属性来创建、读取、修改和删除 Cookie 信息。 name=value
形式的字符串来定义新的 Cookie 信息,如下例所示:document.cookie = "url=http://task.lmcjl.com/";
Cookie 数据中不能包含分号、逗号或空格,因此在将数据存储到 Cookie 之前,可以使用 JavaScript 内置的 encodeURIComponent() 函数对数据进行编码。在读取 Cookie 时,使用对应的 decodeURIComponent() 函数来解析 Cookie 数据,如下例所示:document.cookie = "url=" + encodeURIComponent("http://task.lmcjl.com/");
注意:运行上面的代码,您会发现 Cookie 并没有创建,这是因为 Cookie 是用来与服务器进行交互的,所以要成功创建 Cookie 需要借助服务器环境。您可以阅读《PHP开发环境》一节,来搭建一个简单的开发环境,并将我们定义的 HTML 文件移动到应用目录(默认为安装目录的 apache2/htdocs 目录下)中,然后访问我们的 HTML 文件。
Cookie 并不会一直存在,默认情况下,Cookie 的生命周期就是浏览器的会话周期,即用户关闭浏览器后,Cookie 就会失效。 如果想要延长 Cookie 的生命周期,您可以使用 max-age 属性来指定 Cookie 可以存在的时间(单位为秒),默认为 -1,即关闭浏览器后失效。document.cookie = "url=http://task.lmcjl.com/; max-age=" + 30*24*60*60;
此外,您也可以使用 expires 属性来指定 Cookie 失效的具体日期(GMT/UTC 格式),如下所示:document.cookie = "url=http://task.lmcjl.com/; expires=Sun, 31 Dec 2017 12:00:00 UTC;";
提示:通过为 Cookie 设置生命周期,不仅可以延长 Cookie 存在的时间,还可以让 Cookie 提前失效。
默认情况下,Cookie 可用于同一域名下的所有网页,但如果您为 Cookie 设置了 path 属性,那么 Cookie 就只能在该域名指定路径下的网页中使用,例如网站的域名为 task.lmcjl.com,若 path 属性设置为 /
,则表示 Cookie 可在域名下的所有网页中使用,若 path 属性设置为 /javascript/
,则 Cookie 只可在 http://task.lmcjl.com/javascript/ 下的网页中使用,示例代码如下:document.cookie = "url=http://task.lmcjl.com/; path=/";
如果您希望 Cookie 可以在指定域名下的子域名中使用,则可以通过 domain 属性来设置,默认情况下,Cookie 仅可在设置它的域名下使用,示例代码如下:document.cookie = "url=http://task.lmcjl.com/; path=/; domain=.lmcjl.com";
若将 domain 属性设置为 .lmcjl.com
,则表示 Cookie 可在所有以 lmcjl.com
结尾的域名下使用,注意,domain 属性值的第一个字符 .
不能省略。document.cookie = "url=http://task.lmcjl.com/; path=/; domain=.lmcjl.com; secure";
为了方便设置 Cookie,我们可以定义一个函数,如下所示:/** * 添加 Cookie * @param {[string]} name [Cookie 的名称] * @param {[string]} value [Cookie 的值] * @param {[number]} daysToLive [Cookie 的过期时间] */ function setCookie(name, value, daysToLive) { // 对 cookie 值进行编码以转义其中的分号、逗号和空格 var cookie = name + "=" + encodeURIComponent(value); if(typeof daysToLive === "number") { /* 设置 max-age 属性 */ cookie += "; max-age=" + (daysToLive*24*60*60); } document.cookie = cookie; }
document.cookie
即可,该属性会返回一个字符串,字符串中包含除 max-age、expires、path 和 domain 等属性之外的所有 Cookie 信息,例如 url=http://task.lmcjl.com/; course=JavaScript
。为了获取单个 Cookie 的值,我们可以通过 split() 函数将包含 Cookie 信息的字符串拆分为数组,然后再获取某个 Cookie 的值,示例代码如下:document.cookie = "url=http://task.lmcjl.com/; max-age=" + 30*24*60*60; document.cookie = "course=JavaScript"; document.cookie = "title=cookie"; function getCookie(name) { // 拆分 cookie 字符串 var cookieArr = document.cookie.split(";"); // 循环遍历数组元素 for(var i = 0; i < cookieArr.length; i++) { var cookiePair = cookieArr[i].split("="); /* 删除 cookie 名称开头的空白并将其与给定字符串进行比较 */ if(name == cookiePair[0].trim()) { // 解码cookie值并返回 return decodeURIComponent(cookiePair[1]); } } // 如果未找到,则返回null return null; } document.write("url = " + getCookie("url") + "<br>"); // 输出:url = http://task.lmcjl.com/ document.write("course = " + getCookie("course") + "<br>"); // 输出:course = JavaScript document.write("title = " + getCookie("title")); // 输出:title = cookie
// 创建一个 Cookie document.cookie = "url=http://task.lmcjl.com/; path=/; max-age=" + 30*24*60*60; // 修改这个 Cookie document.cookie = "url=http://task.lmcjl.com/javascript/; path=/; max-age=" + 365*24*60*60;
提示:若 path 属性为 /
,在修改时也可以省略 path 属性。
// 创建一个 Cookie document.cookie = "url=http://task.lmcjl.com/; path=/; max-age=" + 30*24*60*60; // 删除这个 Cookie document.cookie = "url=; expires=Thu, 01 Jan 1970 00:00:00 UTC; path=/;";另外,也可通过将 max-age 属性设置为 0 来删除 Cookie。
本文链接:http://task.lmcjl.com/news/6388.html