Vue-Pinia

定义

Pinia(皮尼亚)是Vue.js官方推荐的下一代状态管理库。

Pinia是一个为 Vue.js 设计的状态管理库。它允许你跨组件或页面共享状态。它的 API 设计非常简洁,与 Vue 3 的 组合 API 完美契合,并且提供了极好的 TypeScript 支持。

pinia既支持Vue2又Vue3的!

基本使用

[1] 安装
javascript 复制代码
npm i pinia
[2] 创建pinia实例
语法说明
示例
javascript 复制代码
import { createApp } from 'vue'
import App from './App.vue'
// [1]导入
import { createPinia } from 'pinia'

// [2]创建pinia实例
const pinia = createPinia()

const app = createApp(App)
// [3]将pinia作为插件使用
app.use(pinia)
app.mount('#app')
[3] 定义一个Store

因为pinia是支持Vue2与Vue3的,所以在定义一个Store时,即支持Option Store 风格也支持Setup Store 风格。

语法说明- defineStore API
javascript 复制代码
import { defineStore } from 'pinia'

defineStore(id, options)
  • id: 作为store的唯一标识
  • options: 一个选项对象或一个 Setup 函数;此衍生出两种定义 Store 的语法风格:Options Store 和 Setup Store
Setup Store 风格
javascript 复制代码
import {ref, computed} from 'vue'
import { defineStore } from 'pinia'

// defineStore创建一个模块,user就是模块名
export const userStore = defineStore('user',()=>{
  // 使用ref定义的数据相当于state中的数据
  const firstName = ref('')
  const lastName = ref('')
  // computed定义的数据相当于getter
  const name = computed(()=> firstName.value+lastName.value)
  // 封装的函数相当于actions
  function editName(){
    firstName.value = 'ren'
    lastName.value = 'niuniu'
  }
  // 移出了mutations这一概念,所有操作都在 actions 中完成
  return {firstName, lastName, editName, name}
})
[4-1] 在组件中使用Store
  • 引入需要使用的store模块

    javascript 复制代码
    import {useUserStore} from '@/store/user'
    // 若是需要直接使用state中的数据还需要引入storeToRefs=>直接解构赋值获取的数据不是响应式的
    import { storeToRefs } from 'pinia'
  • 2\] 使用 ```javascript setup(){ // [1]在setup中调用模块的方法,会返回一个实例对象 const userStore = useUserStore() // [2-1]比如页面需要使用name值,使用storeToRefs解构(响应式) const { name } = storeToRefs(userStore) // [2-2]比如页面需要使用editName方法,直接解构 const { editName } = userStore toEditName(str1,str2){ editName(str1,str2) } // return出去在Dom结构使用 return{ name, toEditName } } ```

javascript 复制代码
import { defineStore } from "pinia";
// [1] 引入其他模块的store
import { useUserStore } from "./user"; 
import { computed } from 'vue'

export const useAuthStore = defineStore('auth', ()=>{
  // [2]  调用方法获取其他模块store实例化对象
  const userInfo = useUserStore()
  // 通过实力化对象获取其他模块的state数据
  const  isAuth= computed(()=> userInfo.name == 'lichaochao')
  

  return { isAuth }
})

优点

相关推荐
likuolei1 小时前
XSL-FO 软件
java·开发语言·前端·数据库
正一品程序员1 小时前
vue项目引入GoogleMap API进行网格区域圈选
前端·javascript·vue.js
j***89461 小时前
spring-boot-starter和spring-boot-starter-web的关联
前端
star_11121 小时前
Jenkins+nginx部署前端vue项目
前端·vue.js·jenkins
im_AMBER1 小时前
Canvas架构手记 05 鼠标事件监听 | 原生事件封装 | ctx 结构化对象
前端·笔记·学习·架构
JIngJaneIL1 小时前
农产品电商|基于SprinBoot+vue的农产品电商系统(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·毕设·农产品电商系统
Tongfront1 小时前
前端通用submit方法
开发语言·前端·javascript·react
可爱又迷人的反派角色“yang”1 小时前
LVS+Keepalived群集
linux·运维·服务器·前端·nginx·lvs
han_1 小时前
前端高频面试题之CSS篇(二)
前端·css·面试
JIngJaneIL1 小时前
书店销售|书屋|基于SprinBoot+vue书店销售管理设计与实现(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·毕设·书店销售管理设计与实现