AVt天堂网 手机版,亚洲va久久久噜噜噜久久4399,天天综合亚洲色在线精品,亚洲一级Av无码毛片久久精品

當(dāng)前位置:首頁(yè) > 科技  > 軟件

使用原生cookieStore方法,讓Cookie操作更簡(jiǎn)單

來(lái)源: 責(zé)編: 時(shí)間:2024-02-29 14:42:53 189觀看
導(dǎo)讀前言對(duì)于前端來(lái)講,我們?cè)诓僮鱟ookie時(shí)往往都是基于document.cookie,但它有一個(gè)缺點(diǎn)就是操作復(fù)雜,它并沒(méi)有像localStorage那樣提供一些get或set等方法供我們使用。對(duì)與cookie的操作一切都是基于字符串來(lái)進(jìn)行的。為了讓coo

前言

對(duì)于前端來(lái)講,我們?cè)诓僮鱟ookie時(shí)往往都是基于document.cookie,但它有一個(gè)缺點(diǎn)就是操作復(fù)雜,它并沒(méi)有像localStorage那樣提供一些get或set等方法供我們使用。對(duì)與cookie的操作一切都是基于字符串來(lái)進(jìn)行的。為了讓cookie的操作更簡(jiǎn)便, Chrome87率先引入了cookieStore方法。PoE28資訊網(wǎng)——每日最新資訊28at.com

document.cookie

document.cookie可以獲取并設(shè)置當(dāng)前文檔關(guān)聯(lián)的cookiePoE28資訊網(wǎng)——每日最新資訊28at.com

獲取cookie

const cookie = document.cookie

在上面的代碼中,cookie 被賦值為一個(gè)字符串,該字符串包含所有的 Cookie,每條 cookie 以"分號(hào)和空格 (; )"分隔 (即, key=value 鍵值對(duì))。PoE28資訊網(wǎng)——每日最新資訊28at.com

圖片圖片PoE28資訊網(wǎng)——每日最新資訊28at.com

但這拿到的是一整個(gè)字符串,如果你想獲取cookie中的某一個(gè)字段,還需要自己處理PoE28資訊網(wǎng)——每日最新資訊28at.com

const converter = {  read: function (value) {    if (value[0] === '"') {      value = value.slice(1, -1);    }    return value.replace(/(%[/dA-F]{2})+/gi, decodeURIComponent)  },  write: function (value) {    return encodeURIComponent(value).replace(      /%(2[346BF]|3[AC-F]|40|5[BDE]|60|7[BCD])/g,      decodeURIComponent    )  }}function getCookie (key) {              const cookies = document.cookie ? document.cookie.split('; ') : [];  const jar = {};  for (let i = 0; i < cookies.length; i++) {    const parts = cookies[i].split('=');    const value = parts.slice(1).join('=');    try {      const foundKey = decodeURIComponent(parts[0]);      jar[foundKey] = converter.read(value, foundKey);      if (key === foundKey) {        break      }    } catch (e) {}  }  return key ? jar[key] : jar}console.log(getCookie('name'))  // 前端南玖

比如上面這段代碼就是用來(lái)獲取單個(gè)cookie值的PoE28資訊網(wǎng)——每日最新資訊28at.com

設(shè)置cookie

document.cookie = `name=前端南玖;`

它的值是一個(gè)鍵值對(duì)形式的字符串。需要注意的是,用這個(gè)方法一次只能對(duì)一個(gè) cookie 進(jìn)行設(shè)置或更新。PoE28資訊網(wǎng)——每日最新資訊28at.com

比如:PoE28資訊網(wǎng)——每日最新資訊28at.com

document.cookie = `age=18; city=shanghai;`

這樣只有age能夠設(shè)置成功PoE28資訊網(wǎng)——每日最新資訊28at.com

  • 以下可選的 cookie 屬性值可以跟在鍵值對(duì)后,用來(lái)具體化對(duì) cookie 的設(shè)定/更新,使用分號(hào)以作分隔:

這個(gè)值的格式參見(jiàn)Date.toUTCString() (en-US)PoE28資訊網(wǎng)——每日最新資訊28at.com

;path=path (例如 '/', '/mydir') 如果沒(méi)有定義,默認(rèn)為當(dāng)前文檔位置的路徑。PoE28資訊網(wǎng)——每日最新資訊28at.com

;domain=domain (例如 'example.com', 'subdomain.example.com') 如果沒(méi)有定義,默認(rèn)為當(dāng)前文檔位置的路徑的域名部分。與早期規(guī)范相反的是,在域名前面加 . 符將會(huì)被忽視,因?yàn)闉g覽器也許會(huì)拒絕設(shè)置這樣的 cookie。如果指定了一個(gè)域,那么子域也包含在內(nèi)。PoE28資訊網(wǎng)——每日最新資訊28at.com

;max-age=max-age-in-seconds (例如一年為 606024*365)PoE28資訊網(wǎng)——每日最新資訊28at.com

;expires=date-in-GMTString-format

如果沒(méi)有定義,cookie 會(huì)在對(duì)話結(jié)束時(shí)過(guò)期PoE28資訊網(wǎng)——每日最新資訊28at.com

;secure (cookie 只通過(guò) https 協(xié)議傳輸)PoE28資訊網(wǎng)——每日最新資訊28at.com

  • cookie 的值字符串可以用encodeURIComponent() (en-US)來(lái)保證它不包含任何逗號(hào)、分號(hào)或空格 (cookie 值中禁止使用這些值).
function assign (target) {  for (var i = 1; i < arguments.length; i++) {    var source = arguments[i];    for (var key in source) {      target[key] = source[key];    }  }  return target}function setCookie (key, value, attributes) {  if (typeof document === 'undefined') {    return  }  attributes = assign({}, { path: '/' }, attributes);  if (typeof attributes.expires === 'number') {    attributes.expires = new Date(Date.now() + attributes.expires * 864e5);  }  if (attributes.expires) {    attributes.expires = attributes.expires.toUTCString();  }  key = encodeURIComponent(key)    .replace(/%(2[346B]|5E|60|7C)/g, decodeURIComponent)    .replace(/[()]/g, escape);  var stringifiedAttributes = '';  for (var attributeName in attributes) {    if (!attributes[attributeName]) {      continue    }    stringifiedAttributes += '; ' + attributeName;    if (attributes[attributeName] === true) {      continue    }    stringifiedAttributes += '=' + attributes[attributeName].split(';')[0];  }  return (document.cookie =          key + '=' + converter.write(value, key) + stringifiedAttributes)}setCookie('course', 'fe', { expires: 365 })

這里是js-cookie庫(kù)對(duì)setCookie方法的封裝PoE28資訊網(wǎng)——每日最新資訊28at.com

刪除cookie

function removeCookie (key, attributes) {  setCookie(    key,    '',    assign({}, attributes, {      expires: -1    })  );}removeCookie('course')

新方法cookieStore

以上就是通過(guò)document.cookie來(lái)操作cookie的方法,未封裝方法之前操作起來(lái)都非常的不方便。現(xiàn)在我們?cè)賮?lái)了解一下新方法cookieStore,它是一個(gè)類似localStorage的全局對(duì)象。PoE28資訊網(wǎng)——每日最新資訊28at.com

圖片圖片PoE28資訊網(wǎng)——每日最新資訊28at.com

它提供了一些方法可以讓我們更加方便的操作cookiePoE28資訊網(wǎng)——每日最新資訊28at.com

獲取單個(gè)cookie

cookieStore.get(name)

該方法可以獲取對(duì)應(yīng)key的單個(gè)cookie,并且以promise形式返回對(duì)應(yīng)的值PoE28資訊網(wǎng)——每日最新資訊28at.com

async function getCookie (key) {  const name = await cookieStore.get(key)  console.log('【name】', name)}getCookie('name')

圖片圖片PoE28資訊網(wǎng)——每日最新資訊28at.com

當(dāng)獲取的cookie不存在時(shí),則會(huì)返回nullPoE28資訊網(wǎng)——每日最新資訊28at.com

獲取所有cookie

cookieStore.getAll()

該方法可以獲取所有匹配的cookie,并且以promise形式返回一個(gè)列表PoE28資訊網(wǎng)——每日最新資訊28at.com

async function getAllCookies () {  const cookies = await cookieStore.getAll()  console.log('【cookies】', cookies)}getAllCookies()

PoE28資訊網(wǎng)——每日最新資訊28at.com

當(dāng)cookie不存在時(shí),則會(huì)返回一個(gè)空數(shù)組PoE28資訊網(wǎng)——每日最新資訊28at.com

設(shè)置cookie

cookieStore.set()

該方法可以設(shè)置cookie,并且會(huì)返回一個(gè)promise狀態(tài),表示是否設(shè)置成功PoE28資訊網(wǎng)——每日最新資訊28at.com

function setCookie (key, value) {  cookieStore.set(key, value).then(res => {    console.log('設(shè)置成功')  }).catch(err => {    console.log('設(shè)置失敗')  })}setCookie('site', 'https://bettersong.github.io/nanjiu/')

如果想要設(shè)置更多的屬性,比如:過(guò)期時(shí)間、路徑、域名等,可以傳入一個(gè)對(duì)象PoE28資訊網(wǎng)——每日最新資訊28at.com

function setCookie (key, value) {  cookieStore.set({    name: key,    value: value,    path: '/',    expires: new Date(2024, 2, 1)  }).then(res => {    console.log('設(shè)置成功')  }).catch(err => {    console.log('設(shè)置失敗')  })}setCookie('site', 'https://bettersong.github.io/nanjiu/')

PoE28資訊網(wǎng)——每日最新資訊28at.com

刪除cookie

cookieStore.delete(name)

該方法可以用來(lái)刪除指定的cookie,同樣會(huì)返回一個(gè)promise狀態(tài),來(lái)表示是否刪除成功PoE28資訊網(wǎng)——每日最新資訊28at.com

function removeCookie (key) {  cookieStore.delete(key).then(res => {    console.log('刪除成功')  }).catch(err => {    console.log('刪除失敗')  })}removeCookie('site')

PoE28資訊網(wǎng)——每日最新資訊28at.com

需要注意的是:即使刪除一個(gè)不存在的cookie也會(huì)返回刪除成功狀態(tài)PoE28資訊網(wǎng)——每日最新資訊28at.com

監(jiān)聽(tīng)cookie

cookieStore.addEventListener('change', (event) => {  console.log(event)});

PoE28資訊網(wǎng)——每日最新資訊28at.com

可以通過(guò)change事件來(lái)監(jiān)聽(tīng)cookie的變化,無(wú)論是通過(guò)cookieStore操作的,還是通過(guò)document.cookie來(lái)操作的都能夠監(jiān)聽(tīng)到。PoE28資訊網(wǎng)——每日最新資訊28at.com

該方法的返回值有兩個(gè)字段比較重要,分別是:change盒delete,它們都是數(shù)組類型。用來(lái)存放改變和刪除的cookie信息PoE28資訊網(wǎng)——每日最新資訊28at.com

監(jiān)聽(tīng)修改

調(diào)用set方法時(shí),會(huì)觸發(fā)change事件,修改或設(shè)置的cookie會(huì)存放在change數(shù)組中PoE28資訊網(wǎng)——每日最新資訊28at.com

cookieStore.addEventListener('change', (event) => {  const type = event.changed.length ? 'change' : 'delete';  const data = (event.changed.length ? event.changed : event.deleted).map((item) => item.name);  console.log(`【${type}】, cookie:${JSON.stringify(data)}`);});function setCookie (key, value) {  cookieStore.set(key, value).then(res => {    console.log('設(shè)置成功')  }).catch(err => {    console.log('設(shè)置失敗')  })}setCookie('site', 'https://bettersong.github.io/nanjiu/')

PoE28資訊網(wǎng)——每日最新資訊28at.com

??需要注意的是:PoE28資訊網(wǎng)——每日最新資訊28at.com

  • 通過(guò)document.cookie設(shè)置或刪除cookie時(shí),都是會(huì)觸發(fā)change事件,不會(huì)觸發(fā)delete事件
  • 即使兩次設(shè)置cookie的name和value都相同,也會(huì)觸發(fā)change事件

監(jiān)聽(tīng)刪除

調(diào)用delete方法時(shí),會(huì)觸發(fā)change事件,刪除的cookie會(huì)存放在delete數(shù)組中PoE28資訊網(wǎng)——每日最新資訊28at.com

cookieStore.addEventListener('change', (event) => {  const type = event.changed.length ? 'change' : 'delete';  const data = (event.changed.length ? event.changed : event.deleted).map((item) => item.name);  console.log(`【${type}】, cookie:${JSON.stringify(data)}`);});function removeCookie (key) {  cookieStore.delete(key).then(res => {    console.log('刪除成功')  }).catch(err => {    console.log('刪除失敗')  })}removeCookie('site')

PoE28資訊網(wǎng)——每日最新資訊28at.com

??需要注意的是:PoE28資訊網(wǎng)——每日最新資訊28at.com

  • 如果刪除一個(gè)不存在的cookie,則不會(huì)觸發(fā)change事件

兼容性

在使用該方法時(shí)需要注意瀏覽器的兼容性PoE28資訊網(wǎng)——每日最新資訊28at.com

PoE28資訊網(wǎng)——每日最新資訊28at.com

總結(jié)

cookieStore提供的方法比起直接操作document.cookie要簡(jiǎn)便許多,不僅支持增刪改查,還支持通過(guò)change事件來(lái)監(jiān)聽(tīng)cookie的變化,但是在使用過(guò)程需要注意兼容性問(wèn)題。PoE28資訊網(wǎng)——每日最新資訊28at.com

本文鏈接:http://www.tebozhan.com/showinfo-26-75335-0.html使用原生cookieStore方法,讓Cookie操作更簡(jiǎn)單

聲明:本網(wǎng)頁(yè)內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問(wèn)題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。郵件:2376512515@qq.com

上一篇: 33張圖探秘OpenFeign核心架構(gòu)原理

下一篇: React 跨平臺(tái)開(kāi)發(fā)指日可待!

標(biāo)簽:
  • 熱門焦點(diǎn)
  • 石頭智能洗地機(jī)A10 Plus體驗(yàn):雙向自清潔治好了我的懶癌

    一、前言和介紹專為家庭請(qǐng)假懶人而生的石頭科技在近日又帶來(lái)了自己的全新旗艦新品,石頭智能洗地機(jī)A10 Plus。從這個(gè)產(chǎn)品名上就不難看出,這次石頭推出的并不是常見(jiàn)的掃地機(jī)器
  • 8月總票房已突破10億!《封神》第一:口碑已經(jīng)成了

    8月5日消息,據(jù)燈塔專業(yè)版數(shù)據(jù),截至8月5日9時(shí)35分,8月總票房(含預(yù)售)已突破10億。其中,《封神》以大比分的優(yōu)勢(shì)領(lǐng)先。根據(jù)官方消息,目前該片總票房已經(jīng)超過(guò)14.
  • JavaScript 混淆及反混淆代碼工具

    介紹在我們開(kāi)始學(xué)習(xí)反混淆之前,我們首先要了解一下代碼混淆。如果不了解代碼是如何混淆的,我們可能無(wú)法成功對(duì)代碼進(jìn)行反混淆,尤其是使用自定義混淆器對(duì)其進(jìn)行混淆時(shí)。什么是混
  • K8S | Service服務(wù)發(fā)現(xiàn)

    一、背景在微服務(wù)架構(gòu)中,這里以開(kāi)發(fā)環(huán)境「Dev」為基礎(chǔ)來(lái)描述,在K8S集群中通常會(huì)開(kāi)放:路由網(wǎng)關(guān)、注冊(cè)中心、配置中心等相關(guān)服務(wù),可以被集群外部訪問(wèn);圖片對(duì)于測(cè)試「Tes」環(huán)境或者
  • 得物效率前端微應(yīng)用推進(jìn)過(guò)程與思考

    一、背景效率工程隨著業(yè)務(wù)的發(fā)展,組織規(guī)模的擴(kuò)大,越來(lái)越多的企業(yè)開(kāi)始意識(shí)到協(xié)作效率對(duì)于企業(yè)團(tuán)隊(duì)的重要性,甚至是決定其在某個(gè)行業(yè)競(jìng)爭(zhēng)中突圍的關(guān)鍵,是企業(yè)長(zhǎng)久生存的根本。得物
  • 如何通過(guò)Python線程池實(shí)現(xiàn)異步編程?

    線程池的概念和基本原理線程池是一種并發(fā)處理機(jī)制,它可以在程序啟動(dòng)時(shí)創(chuàng)建一組線程,并將它們置于等待任務(wù)的狀態(tài)。當(dāng)任務(wù)到達(dá)時(shí),線程池中的某個(gè)線程會(huì)被喚醒并執(zhí)行任務(wù),執(zhí)行完任
  • JavaScript學(xué)習(xí) -AES加密算法

    引言在當(dāng)今數(shù)字化時(shí)代,前端應(yīng)用程序扮演著重要角色,用戶的敏感數(shù)據(jù)經(jīng)常在前端進(jìn)行加密和解密操作。然而,這樣的操作在網(wǎng)絡(luò)傳輸和存儲(chǔ)中可能會(huì)受到惡意攻擊的威脅。為了確保數(shù)據(jù)
  • 一文搞定Java NIO,以及各種奇葩流

    大家好,我是哪吒。很多朋友問(wèn)我,如何才能學(xué)好IO流,對(duì)各種流的概念,云里霧里的,不求甚解。用到的時(shí)候,現(xiàn)百度,功能雖然實(shí)現(xiàn)了,但是為什么用這個(gè)?不知道。更別說(shuō)效率問(wèn)題了~下次再遇到,
  • 梁柱接棒兩年,騰訊音樂(lè)闖出新路子

    文丨田靜 出品丨牛刀財(cái)經(jīng)(niudaocaijing)7月5日,企鵝FM發(fā)布官方公告稱由于業(yè)務(wù)調(diào)整,將于9月6日正式停止運(yùn)營(yíng),這意味著騰訊音樂(lè)長(zhǎng)音頻業(yè)務(wù)走向消亡。騰訊在長(zhǎng)音頻領(lǐng)域還在摸索。為
Top