跳转到内容

在 Astro 组件中共享状态

在构建 Astro 网站时,你可能需要在组件之间共享状态。Astro 推荐使用 Nano Stores 来进行客户端的存储共享。

  1. 安装 Nano Stores:
Terminal window
npm install nanostores
  1. 创建一个存储(store)。在这个例子中,该存储用于跟踪对话框是否打开:
src/store.js
import { atom } from 'nanostores';
export const isOpen = atom(false);
  1. 在要共享状态的组件的 <script> 标签中导入并使用存储。

如下的 Button and Dialog 组件分别使用了共享的 isOpen 状态来控制特定的 <div> 元素是否隐藏或显示:

src/components/Button.astro
<button id="openDialog">Open</button>
<script>
import { isOpen } from '../store.js';
// 当按钮被点击时将状态设置为 true
function 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';
}
})
document.getElementById('openDialog').addEventListener('click', openDialog);
</script>