javascript基础从小白到高手系列六百三十九:cookie 的构成

cookie 在浏览器中是由以下参数构成的。
 名称:唯一标识cookie 的名称。cookie 名不区分大小写,因此myCookie 和MyCookie 是同一
个名称。不过,实践中最好将cookie 名当成区分大小写来对待,因为一些服务器软件可能这样
对待它们。cookie 名必须经过URL 编码。
 值:存储在cookie 里的字符串值。这个值必须经过URL 编码。
 域:cookie 有效的域。发送到这个域的所有请求都会包含对应的cookie。这个值可能包含子域(如
www.wrox.com),也可以不包含(如.wrox.com 表示对wrox.com 的所有子域都有效)。如果不明
确设置,则默认为设置cookie 的域。
 路径:请求URL 中包含这个路径才会把cookie 发送到服务器。例如,可以指定cookie 只能由
http://www.wrox.com/books/访问,因此访问http://www.wrox.com/下的页面就不会发送cookie,即
使请求的是同一个域。
 过期时间:表示何时删除cookie 的时间戳(即什么时间之后就不发送到服务器了)。默认情况下,
浏览器会话结束后会删除所有cookie。不过,也可以设置删除cookie 的时间。这个值是GMT 格
式(Wdy, DD-Mon-YYYY HH:MM:SS GMT),用于指定删除cookie 的具体时间。这样即使关闭
浏览器cookie 也会保留在用户机器上。把过期时间设置为过去的时间会立即删除cookie。
 安全标志:设置之后,只在使用SSL 安全连接的情况下才会把cookie 发送到服务器。例如,请
求https://www.wrox.com 会发送cookie,而请求http://www.wrox.com则不会。
这些参数在Set-Cookie 头部中使用分号加空格隔开,比如:
HTTP/1.1 200 OK
Content-type: text/html
Set-Cookie: name=value; expires=Mon, 22-Jan-07 07:10:24 GMT; domain=.wrox.com
Other-header: other-header-value
这个头部设置一个名为"name"的cookie,这个cookie 在2007 年1 月22 日7:10:24 过期,对
www.wrox.com 及其他wrox.com的子域(如p2p.wrox.com)有效。
安全标志secure 是cookie 中唯一的非名/值对,只需一个secure 就可以了。比如:
HTTP/1.1 200 OK
Content-type: text/html
Set-Cookie: name=value; domain=.wrox.com; path=/; secure
Other-header: other-header-value
这里创建的cookie 对所有wrox.com 的子域及该域中的所有页面有效(通过path=/指定)。不过,
这个cookie 只能在SSL 连接上发送,因为设置了secure 标志。
要知道,域、路径、过期时间和secure 标志用于告诉浏览器什么情况下应该在请求中包含cookie。
这些参数并不会随请求发送给服务器,实际发送的只有cookie 的名/值对。
JavaScript 中的cookie
在JavaScript 中处理cookie 比较麻烦,因为接口过于简单,只有BOM的document.cookie 属性。
根据用法不同,该属性的表现迥异。要使用该属性获取值时,document.cookie 返回包含页面中所有
有效cookie 的字符串(根据域、路径、过期时间和安全设置),以分号分隔,如下面的例子所示:
name1=value1;name2=value2;name3=value3
所有名和值都是URL 编码的,因此必须使用decodeURIComponent()解码。
在设置值时,可以通过document.cookie 属性设置新的cookie 字符串。这个字符串在被解析后会
添加到原有cookie 中。设置document.cookie 不会覆盖之前存在的任何cookie,除非设置了已有的
cookie。设置cookie 的格式如下,与Set-Cookie 头部的格式一样:
name=value; expires=expiration_time; path=domain_path; domain=domain_name; secure
在所有这些参数中,只有cookie 的名称和值是必需的。下面是个简单的例子:
document.cookie = “name=Nicholas”;
这行代码会创建一个名为"name"的会话cookie,其值为"Nicholas"。这个cookie 在每次客户端向
服务器发送请求时都会被带上,在浏览器关闭时就会被删除。虽然这样直接设置也可以,因为不需要在
名称或值中编码任何字符,但最好还是使用encodeURIComponent()对名称和值进行编码,比如:
document.cookie = encodeURIComponent(“name”) + “=” +
encodeURIComponent(“Nicholas”);
要为创建的cookie 指定额外的信息,只要像Set-Cookie 头部一样直接在后面追加相同格式的字
符串即可:
document.cookie = encodeURIComponent(“name”) + “=” +
encodeURIComponent(“Nicholas”) + “; domain=.wrox.com; path=/”;
因为在JavaScript 中读写cookie 不是很直观,所以可以通过辅助函数来简化相应的操作。与cookie
相关的基本操作有读、写和删除。这些在CookieUtil 对象中表示如下:
class CookieUtil {
static get(name) {
let cookieName = ${encodeURIComponent(name)}=,
cookieStart = document.cookie.indexOf(cookieName),
cookieValue = null;
if (cookieStart > -1){
let cookieEnd = document.cookie.indexOf(“;”, cookieStart);
if (cookieEnd == -1){
cookieEnd = document.cookie.length;
}
cookieValue = decodeURIComponent(document.cookie.substring(cookieStart

  • cookieName.length, cookieEnd));
    }
    return cookieValue;
    }
    static set(name, value, expires, path, domain, secure) {
    let cookieText =
    ${encodeURIComponent(name)}=${encodeURIComponent(value)}
    if (expires instanceof Date) {
    cookieText += ; expires=${expires.toGMTString()};
    }
    if (path) {
    cookieText += ; path=${path};
    }
    if (domain) {
    cookieText += ; domain=${domain};
    }
    if (secure) {
    cookieText += “; secure”;
    }
    document.cookie = cookieText;
    }
    static unset(name, path, domain, secure) {
    CookieUtil.set(name, “”, new Date(0), path, domain, secure);
    }
    };
    CookieUtil.get()方法用于取得给定名称的cookie 值。为此,需要在document.cookie 返回的
    字符串中查找是否存在名称后面加上等号。如果找到了,则使用indexOf()再查找该位置后面的分号
    (表示该cookie 的末尾)。如果没有找到分号,说明这个cookie 在字符串末尾,因此字符串剩余部分都是
    cookie 的值。取得cookie 值后使用decodeURIComponent()解码,然后返回。如果没有找到cookie,
    则返回null。
    CookieUtil.set()方法用于设置页面上的cookie,接收多个参数:cookie 名称、cookie 值、可
    选的Date 对象(表示何时删除cookie)、可选的URL 路径、可选的域以及可选的布尔值(表示是否添
    加secure 标志)。这些参数以它们的使用频率为序,只有前两个是必需的。在方法内部,使用了encodeURIComponent()对名称和值进行编码,然后再依次检查其他参数。如果expires 参数是Date
    对象,则使用Date 对象的toGMTString()方法添加一个expires 选项来获得正确的日期格式。剩下
    的代码就是简单地追加cookie 字符串,最终设置给document.cookie。
    没有直接删除已有cookie 的方法。为此,需要再次设置同名cookie(包括相同路径、域和安全选项),
    但要将其过期时间设置为某个过去的时间。CookieUtil.unset()方法实现了这些处理。这个方法接收
    4 个参数:要删除cookie 的名称、可选的路径、可选的域和可选的安全标志。
    这些参数会传给CookieUtil.set(),将cookie 值设置为空字符串,将过期时间设置为1970 年
    1 月1 日(以0 毫秒初始化的Date 对象的值)。这样可以保证删除cookie。
    可以像下面这样使用这些方法:
    // 设置cookie
    CookieUtil.set(“name”, “Nicholas”);
    CookieUtil.set(“book”, “Professional JavaScript”);
    // 读取cookie
    alert(CookieUtil.get(“name”)); // “Nicholas”
    alert(CookieUtil.get(“book”)); // “Professional JavaScript”
    // 删除cookie
    CookieUtil.unset(“name”);
    CookieUtil.unset(“book”);
    // 设置有路径、域和过期时间的cookie
    CookieUtil.set(“name”, “Nicholas”, “/books/projs/”, “www.wrox.com”,
    new Date(“January 1, 2010”));
    // 删除刚刚设置的cookie
    CookieUtil.unset(“name”, “/books/projs/”, “www.wrox.com”);
    // 设置安全cookie
    CookieUtil.set(“name”, “Nicholas”, null, null, null, true);
    这些方法通过处理解析和cookie 字符串构建,简化了使用cookie 存储数据的操作。
  • 3
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: HTML DOM(文档对象模型)是一种编程接口,允许程序访问和操作HTML文档中的元素。使用JavaScript来操作HTML DOM可以让网页具有交互性和动态性。 在JavaScript中,可以使用getElementById,getElementsByTagName和getElementsByClassName等方法来获取页面上的元素。例如,通过getElementById("myId")可以获取id为"myId"的元素。 操作元素的属性和内容也很简单,可以使用如下方法: - 修改元素的属性:element.attribute = new value - 访问元素的属性:element.attribute - 修改元素的内容:element.innerHTML = new content - 访问元素的内容:element.innerHTML 通过操作HTML DOM,可以实现各种交互效果和动态效果。例如,可以在点击按钮时显示或隐藏元素,或在输入框中输入文本时实时更新页面内容等。 ### 回答2: HTML DOM是JavaScript操作网页中元素和属性的主要方式之一。在HTML DOM中,文档元素是指HTML页面中所有元素的根节点。文档元素的操作包括获取元素、创建元素、删除元素、修改元素属性等。 获取元素是HTML DOM操作的重要一环。在JavaScript中,可以使用getElementById()、getElementsByTagName()、getElementsByClassName()等方法获得HTML页面中的元素。其中getElementById()方法可以通过元素的ID获取该元素的引用,常用于根据ID修改元素的属性或内容。而getElementsByTagName()方法可以通过标签名获取HTML页面中所有该标签的元素,例如获取所有的h1元素,常用于对整个页面的控制。getElementsByClassName()方法可以通过class属性获取HTML页面中所有具有该class的元素。 创建元素是向HTML页面中添加元素的重要方式。可以使用createElement()方法创建一个新元素,然后使用appendChild()方法将其添加到现有元素中。例如,创建一个新的p元素,并将其添加到body元素中可以使用以下代码: var newPara = document.createElement("p"); var textNode = document.createTextNode("This is a new paragraph."); newPara.appendChild(textNode); document.body.appendChild(newPara); 删除元素也是HTML DOM中的一个常用操作。可以使用removeChild()方法删除现有元素,例如: var parent = document.getElementById("parent-id"); var child = document.getElementById("child-id"); parent.removeChild(child); 修改元素属性是HTML DOM中的另一个核心操作。可以使用setAttribute()方法修改元素的属性值,例如: var element = document.getElementById("my-id"); element.setAttribute("class", "new-class"); 可以通过HTML DOM操作文档元素,实现对页面元素和属性的各种操作。掌握HTML DOM的知识,可以更好地控制和管理HTML页面。 ### 回答3: HTML DOM是JavaScript操作网页元素的主要方式之一,它的核心在于文档对象模型(DOM,Document Object Model),需要熟悉DOM才能灵活操作网页元素。文档元素是HTML页面中的根元素,它是其他所有元素的祖先元素,也是HTML DOM操作的基础。 一、获取元素 在JavaScript中,我们可以通过各种方式来获取文档元素,例如getElementById()、getElementsByTagName()、getElementsByClassName()等。其中,通过id、标签名和类名获取元素是最常用的三种方法。 1. getElementById() 此方法用于获取具有指定id属性的元素,其语法为document.getElementById(id)。id属性在整个HTML文档中应该是唯一的。 示例:获取id为“demo”的元素 ``` var demo = document.getElementById("demo”); ``` 2. getElementsByTagName() 此方法用于获取具有指定标签名的元素,其语法为document.getElementsByTagName(tagname)。 示例:获取所有p元素 ``` var pList = document.getElementsByTagName("p"); ``` 3. getElementsByClassName() 此方法用于获取具有指定类名的元素,其语法为document.getElementsByClassName(classname)。 示例:获取类名为“red”的元素 ``` var redList = document.getElementsByClassName("red"); ``` 二、改变元素 有很多种方法可以改变文档元素的属性和样式,下面列举一些常见的方法: 1. 修改元素的文本内容 我们可以通过innerHTML属性和innerText属性来修改元素的文本内容。 innerHTML属性用于改变元素的HTML内容,其语法为element.innerHTML=new html content; innerText属性用于改变元素的纯文本内容,其语法为element.innerText=new text content; 2. 修改元素的样式 我们可以通过style属性来修改元素的样式,其中style属性包含了元素的所有样式属性。 示例:将id为“demo”的元素背景色改为红色 ``` document.getElementById("demo").style.backgroundColor = "red"; ``` 3. 创建新元素 我们可以使用document.createElement()方法来创建新元素,并通过appendChild()方法将其加入到指定的元素内。 示例:创建一个新的p元素 ``` var newP = document.createElement("p"); ``` 4. 删除元素 我们可以使用parentNode.removeChild()方法来删除指定的元素。 示例:删除id为“demo”的元素 ``` var demo = document.getElementById("demo"); demo.parentNode.removeChild(demo); ``` 三、总结 通过这篇文章的学习,我们了解了HTML DOM的基础知识和基本操作方法,例如获取元素、改变元素的属性和样式以及创建和删除元素等。掌握这些操作方法可以帮助我们更好地操作网页元素,从而实现丰富多彩的网页效果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值