ExtendableCookieChangeEvent:changed 属性

安全上下文: 此项功能仅在一些支持的浏览器安全上下文(HTTPS)中可用。

io error: No such file or directory (os error 2) (/home/runner/work/yari/yari/mdn/translated-content/files/zh-cn/web/api/extendablecookiechangeevent/index.md)

备注: 此特性仅在 Service Worker 中可用。

ExtendableCookieChangeEvent 接口的 changed 只读属性返回给定 ExtendableCookieChangeEvent 实例已变更的 cookie。

一个包含已变更的 cookie 的对象数组。每个对象包含以下属性:

name

记录 cookie 名称的字符串。

value

记录 cookie 的值的字符串。

domain

记录 cookie 域名的字符串。

path

记录 cookie 路径的字符串。

expires

Unix 时间戳(以毫秒为单位表示),记录 cookie 的到期日期。

secure

一个布尔值,表示 cookie 是否仅在安全上下文中使用(HTTPS 而不是 HTTP)。

sameSite

以下 SameSite 的值之一:

"strict"

Cookie 只会在第一方上下文中发送,不会与第三方网站发起的请求一起发送。

"lax"

Cookie 不会在正常的跨站点子请求(例如将图像或框架加载到第三方站点)中发送,而是在用户在原始站点内导航时(即点击链接时)发送。

"none"

Cookie 将被发送至所有上下文。

partitioned

一个布尔值,表示 cookie 是否是分区 cookie(true)或(false)。更多信息请参阅具有独立分区状态的 Cookie(CHIPS)

示例

此示例中,在 cookie 被设置时,事件监听器打印 changed 属性至控制台。数组的第一个元素代表刚被设置的 cookie 的对象。

js
self.addEventListener("cookiechange", (event) => {
  console.log(event.changed[0]);
});

const one_day = 24 * 60 * 60 * 1000;
cookieStore.set({
  name: "cookie1",
  value: "cookie1-value",
  expires: Date.now() + one_day,
  domain: "example.com",
});

规范

Specification
Cookie Store API
# dom-extendablecookiechangeevent-changed

浏览器兼容性

BCD tables only load in the browser