返回介绍

useCookie

发布于 2024-04-18 00:42:19 字数 1838 浏览 0 评论 0 收藏 0

useCookie 是一个 SSR 友好的可组合对象,用于读取和写入 cookie。

useCookie

在您的页面、组件和插件中,您可以使用useCookie,这是一个 SSR 友好的可组合项,用于读取和写入 cookie。

js
const cookie = useCookie(name, options)

useCookie 仅在 setupLifecycle Hooks 期间有效。

useCookie ref 会自动将 cookie 值序列化和反序列化为 JSON。

示例

下面的示例创建了一个名为 counter 的 cookie。 如果 cookie 不存在,它最初被设置为一个随机值。 每当我们更新 counter 变量时,cookie 都会相应更新。

vue
<template>
  <div>
    <h1>Counter: {{ counter || '-' }}</h1>
    <button @click="counter = null">reset</button>
    <button @click="counter--">-</button>
    <button @click="counter++">+</button>
  </div>
</template>

<script setup>
const counter = useCookie('counter')
counter.value = counter.value || Math.round(Math.random() * 1000)
</script>
案例演示:在StackBlitz编辑

选项

Cookie 可组合项接受多个选项,让您可以修改 cookie 的行为。

大多数选项将直接传递给 cookie 包。

maxAge / expires

您可以使用 h3 包中的 getCookiesetCookie 在服务器 API 路由中设置 cookie。

示例:

js
export default defineEventHandler(event => {
  // 读取计数器 cookie
  let counter = getCookie(event, 'counter') || 0

  // 将计数器 cookie 增加 1
  setCookie(event, 'counter', ++counter)

  // 发送 JSON 响应
  return { counter }
})

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文