title | description | i18nReady | type |
---|---|---|---|
在 Astro 组件中共享状态 |
了解如何通过 Nano Stores 在 Astro 组件中共享状态。 |
true |
recipe |
import { Steps } from '@astrojs/starlight/components'; import PackageManagerTabs from '~/components/tabs/PackageManagerTabs.astro';
:::tip 想使用框架组件?请参考 共享状态。 :::
在构建 Astro 网站时,你可能需要在组件之间共享状态。Astro 推荐使用 Nano Stores 来进行客户端的存储共享。
1. 安装 Nano Stores:<PackageManagerTabs>
<Fragment slot="npm">
```shell
npm install nanostores
```
</Fragment>
<Fragment slot="pnpm">
```shell
pnpm add nanostores
```
</Fragment>
<Fragment slot="yarn">
```shell
yarn add nanostores
```
</Fragment>
</PackageManagerTabs>
-
创建一个存储(store)。在这个例子中,该存储用于跟踪对话框是否打开:
import { atom } from 'nanostores'; export const isOpen = atom(false);
-
在要共享状态的组件的
<script>
标签中导入并使用存储。如下的
Button
andDialog
组件分别使用了共享的isOpen
状态来控制特定的<div>
元素是否隐藏或显示:<button id="openDialog">Open</button> <script> import { isOpen } from '../store.js'; // 当按钮被点击时将状态设置为 true function openDialog() { isOpen.set(true); } // 为按钮添加一个事件侦听器 document.getElementById('openDialog').addEventListener('click', openDialog); </script>
<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>