vue3当中使用Pinia的store的组件化开发模式

一、安装与初始化

  1. 安装Pinia

    npm install pinia  # 或 yarn add pinia
    

    目的:引入Pinia核心库,为状态管理提供基础支持。

  2. 挂载Pinia实例
    main.js中初始化并注入Vue应用:

    import { createApp } from 'vue'
    import { createPinia } from 'pinia'
    import App from './App.vue'
    
    const app = createApp(App)
    const pinia = createPinia()
    app.use(pinia)  // 关键!全局启用Pinia
    app.mount('#app')
    

    作用:创建Pinia实例并与Vue3应用集成,使所有组件可访问Store。


二、创建Store(函数式写法)

使用Composition API风格定义Store(推荐):

// stores/counter.js
import { defineStore } from 'pinia'
import { ref, computed } from 'vue'

export const useCounterStore = defineStore('counter', () => {
  // 1. 定义状态(相当于data)
  const count = ref(0)
  
  // 2. 定义计算属性(相当于getters)
  const doubleCount = computed(() => count.value * 2)
  
  // 3. 定义操作方法(相当于actions)
  function increment() {
    count.value++
  }

  // 暴露状态与方法
  return { count, doubleCount, increment }
})

核心要点

  • defineStore第一个参数为Store唯一ID(需全局唯一)
  • 使用ref/computed等响应式API管理状态
  • 通过函数返回值暴露需共享的状态与方法
  • 注意这个的id和实际没什么关系,你最后还是使用useCounterStore 来获取对象

三、在组件中使用Store

  1. 引入Store实例
    在组件<script setup>中调用Store:

    <script setup>
    import { useCounterStore } from '@/stores/counter'
    const counterStore = useCounterStore() // 实例化Store
    </script>
    

    特性:Store按需实例化,支持多组件复用且状态自动同步。

  2. 模板中访问状态与方法

   <template>
     <div>
       <p>当前计数:{{ counterStore.count }}</p>
       <p>双倍计数:{{ counterStore.doubleCount }}</p>
       <button @click="counterStore.increment()">+1</button>
     </div>
   </template>

响应式原理:直接访问Store的属性会触发Vue的响应式更新。


四、高级功能扩展

1. 状态持久化(示例)

安装插件并配置:

npm install pinia-plugin-persistedstate
// main.js
import piniaPluginPersistedstate from 'pinia-plugin-persistedstate'
pinia.use(piniaPluginPersistedstate)

在Store中启用:

defineStore('counter', () => { /* ... */ }, {
  persist: {
    enabled: true,  // 开启持久化
    storage: sessionStorage,  // 可选存储方式(默认localStorage)
    paths: ['count']  // 指定需持久化的字段
  }
})

作用:浏览器刷新后自动恢复指定状态。

2. 模块化开发

• 创建多个Store文件(如userStore.jscartStore.js
• 组件按需引入不同Store,实现逻辑解耦


五、调试技巧

  1. Vue Devtools集成
    安装浏览器插件后,可查看Store状态变化历史与时间旅行调试。
  2. 自定义插件
    可开发日志插件跟踪状态变更(示例见网页4的日志监控代码)。

总结

通过以上步骤可实现:
• ✅ 响应式状态管理:基于Composition API的Store声明
• ✅ 跨组件共享:多组件间高效同步复杂状态
• ✅ 可维护性:模块化Store设计与类型安全(天然支持TS)
• ✅ 扩展性:通过插件实现持久化、日志等高级功能

对比Vuex,Pinia的函数式Store语法更简洁,且与Vue3的Composition API深度契合,推荐作为Vue3项目的首选状态管理方案。

Vue3是一种流行的JavaScript框架,用于构建用户界面。Vue Router是Vue.js的官方路由器,用于实现单页面应用程序的导航功能。Vite是一个快速的Web开发构建工具,具有即时重载和快速的开发体验。Pinia是一个简单、快速、类型安全的状态管理库。 使用Vue3Vue Router、Vite和Pinia进行组件化开发实战入门非常简单。 首先,我们需要安装Vue3和相关的库。可以使用npm或yarn来安装它们。在项目的根目录中运行以下命令: ``` npm install vue@next vue-router@next @pinia/vue@next vite --save ``` 安装完成后,我们可以开始创建一个Vue应用程序。在项目的根目录中创建一个`src`文件夹,并在其中创建一个`main.js`文件。在`main.js`文件中,我们需要导入VueVue Router和Pinia,并创建一个Vue实例。代码示例如下: ```javascript // main.js import { createApp } from &#39;vue&#39;; import { createRouter, createWebHistory } from &#39;vue-router&#39;; import { createPinia } from &#39;pinia&#39;; // 导入组件 import App from &#39;./App.vue&#39;; // 创建路由 const router = createRouter({ history: createWebHistory(), routes: [ // 定义路由 { path: &#39;/&#39;, component: Home } ] }); // 创建 Pinia 实例 const pinia = createPinia(); // 创建 Vue 实例 const app = createApp(App); // 使用路由和 Pinia app.use(router); app.use(pinia); // 挂载应用 app.mount(&#39;#app&#39;); ``` 现在,我们可以创建一个简单的Vue组件。在`src`文件夹中创建一个名为`App.vue`的文件,并在其中定义一个组件。在组件中,我们可以使用Pinia来管理组件的状态,使用Vue Router来处理导航。 ```html <!-- App.vue --> <template> <div> <router-view></router-view> <button @click="increment">增加计数器</button> <p>{{ count }}</p> </div> </template> <script> import { defineComponent } from &#39;vue&#39;; import { useCounter } from &#39;../store&#39;; export default defineComponent({ setup() { const counter = useCounter(); const increment = () => { counter.increment(); }; return { count: counter.count, increment }; } }); </script> ``` 在上述示例中,我们创建了一个Counter组件,其中包含一个用于增加计数器的按钮和一个显示计数器值的段落。我们使用Pinia的`useCounter`钩子来访问和修改计数器的状态。 最后,在项目的根目录中运行以下命令启动应用程序: ``` npm run dev ``` 以上就是使用Vue3Vue Router、Vite和Pinia进行组件化开发实战入门的一个简单示例。通过深入学习这些工具和框架,您将能够构建更复杂、功能丰富的应用程序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

堕落年代

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值