在 Astro 组件中共享状态
想使用框架组件?请参考 共享状态。
在构建 Astro 网站时,你可能需要在组件之间共享状态。Astro 推荐使用 Nano Stores 来进行客户端的存储共享。
操作步骤
段落标题 操作步骤-
安装 Nano Stores:
Terminal window npm install nanostoresTerminal window pnpm add nanostoresTerminal window yarn add nanostores -
创建一个存储(store)。在这个例子中,该存储用于跟踪对话框是否打开:
src/store.js import { atom } from 'nanostores';export const isOpen = atom(false); -
在要共享状态的组件的
<script>
标签中导入并使用存储。如下的
Button
andDialog
组件分别使用了共享的isOpen
状态来控制特定的<div>
元素是否隐藏或显示:src/components/Button.astro <button id="openDialog">Open</button><script>import { isOpen } from '../store.js';// 当按钮被点击时将状态设置为 truefunction openDialog() {isOpen.set(true);}// 为按钮添加一个事件侦听器document.getElementById('openDialog').addEventListener('click', openDialog);</script>src/components/Dialog.astro <div id="dialog" style="display: hidden">Hello world!</div><script>import { isOpen } from '../store.js';// 侦听状态的修改并相应地显示(或隐藏)对话框isOpen.subscribe(open => {if (open) {document.getElementById('dialog').style.display = 'block';} else {document.getElementById('dialog').style.display = 'none';}})</script>