useCookie
有助于在 CookieStore 中存储、更新和删除值的 hook
useCookie 按键管理单个浏览器 cookie。它返回一个 [cookieValue, updateCookie, refreshCookie] 元组。使用字符串调用 updateCookie 设置 cookie,使用 undefined 调用则删除它。refreshCookie 函数从存储中重新读取 cookie,这在 cookie 可能被外部修改时很有用。选项直接传递给 js-cookie,用于控制路径、域名、过期时间和其他 cookie 属性。
使用场景
- 将用户偏好(语言环境、主题、同意标志)持久化在 cookie 中,以便服务端访问
- 读写存储在 cookie 中的认证或会话令牌
- 当外部代码(分析、第三方脚本)也可能修改 cookie 时,在组件中同步 cookie 状态
注意事项
- SSR 注意事项:使用 SSR 时传入
defaultValue,这样在客户端document.cookie可用之前 hook 就有值。 - 无跨组件同步:在一个组件中更新 cookie 不会自动触发使用同一键的其他组件重新渲染。如果需要,请使用广播机制。
- 参见
useLocalStorage和useSessionStorage了解通过storage事件提供跨标签页同步的 Web Storage 替代方案。
Usage
Live Editor
function Demo() { const defaultOption = { path: "/", }; const cookieName = "cookie-key"; const [cookieValue, updateCookie, refreshCookie] = useCookie( cookieName, defaultOption, "default-value", ); const updateButtonClick = () => { updateCookie("new-cookie-value"); }; const deleteButtonClick = () => { updateCookie(undefined); }; const change = () => { if ("cookieStore" in window) { const store = window.cookieStore as any; store.set({ name: cookieName, value: "changed" }); } else { document.cookie = `${cookieName}=changed; path=/`; } }; return ( <div> <p>点击按钮来更新或清除cookie</p> <p color="blue">cookie: {cookieValue || "无值"}</p> <button onClick={updateButtonClick}>更新cookie</button> <button onClick={deleteButtonClick}>清除cookie</button> <button onClick={change}> 通过其他方法更改cookie </button> <button onClick={refreshCookie}>刷新cookie</button> </div> ); }
Result
API
useCookie
Returns
readonly [UseCookieState, (newValue: UseCookieState | ((prevState: UseCookieState) => UseCookieState)) => void, () => void]: 包含以下元素的元组:
- cookie 的当前值。
- 更新 cookie 值的函数。
- 刷新 cookie 值的函数,以防其他事件更改它。
Arguments
| 参数名 | 描述 | 类型 | 默认值 |
|---|---|---|---|
| key | 键值 | string (必填) | - |
| options | 透传给 js-cookie 的参数 | any | - |
| defaultValue | 默认值,ssr必须传递 | string | undefined | - |
useCookieState
Type
export type UseCookieState = string | undefined