ExtendableCookieChangeEvent: changed property

Limited availability

This feature is not Baseline because it does not work in some of the most widely-used browsers.

Secure context: This feature is available only in secure contexts (HTTPS), in some or all supporting browsers.

Note: This feature is only available in Service Workers.

The changed read-only property of the ExtendableCookieChangeEvent interface returns any cookies that have been changed by the given ExtendableCookieChangeEvent instance.

Value

An array of objects containing the changed cookie(s). Each object contains the following properties:

name

A string containing the name of the cookie.

value

A string containing the value of the cookie.

domain

A string containing the domain of the cookie.

path

A string containing the path of the cookie.

expires

A timestamp, given as Unix time in milliseconds, containing the expiration date of the cookie.

secure

A boolean indicating whether the cookie is used only in a secure context (HTTPS rather than HTTP).

sameSite

One of the following SameSite values:

"strict"

Cookies will only be sent in a first-party context and not be sent with requests initiated by third party websites.

"lax"

Cookies are not sent on normal cross-site subrequests (for example to load images or frames into a third party site), but are sent when a user is navigating within the origin site (i.e. when following a link).

"none"

Cookies will be sent in all contexts.

partitioned

A boolean indicating whether the cookie is a partitioned cookie (true) or not (false). See Cookies Having Independent Partitioned State (CHIPS) for more information.

Examples

In this example when the cookie is set, the event listener logs the changed property to the console. The first item in that array contains an object representing the cookie that has just been set.

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",
});

Specifications

Specification
Cookie Store API
# dom-extendablecookiechangeevent-changed

Browser compatibility

BCD tables only load in the browser