vue3 状态管理器 pinia 用法笔记1

相关链接:

https://pinia.vuejs.org/zh/

简介

pinia是vue的状态管理库,有时候,不同页面、组件间的数据需要进行共享,pinia可用于跨组件或页面的共享状态。

可以把pinia当做一个全局组件,任何其他组件都可以往pinia中读取和写入。

安装

javascript 复制代码
npm install pinia

简单例子

试想这样一种情况,在项目中,需要在多个地方获取当前登录用户信息,在项目的某个地方,需要往仓库中写入当前用户信息,并在需要获取用户信息的地方对仓库进行调用,有时候也可能修改仓库中的信息。

如何通过pinia实现这个逻辑呢?先让我们学习一下pinia的基础用法:

基础用法

pinia使用defineStore方法定义仓库,首先引入defineStore方法:

javascript 复制代码
import { defineStore } from 'pinia'

调用defineStore方法返回创建的仓库调用对象,调用语法:

javascript 复制代码
defineStore(仓库名, {
  对象形式的仓库配置,或者setup风格的属性及方法定义
})

对象形式的仓库配置

pinia store具有三个属性:state、actions、getters,各相当于组件中的data、methods、computed。

定义仓库配置:

javascript 复制代码
export const useCounterStore = defineStore('counter', {
  state: () => ({ count: 0, name: 'Eduardo' }),
  getters: {
    doubleCount: (state) => state.count * 2,
  },
  actions: {
    increment() {
      this.count++
    },
  },
})

使用定义的配置创建仓库实例:

javascript 复制代码
<script setup>
import { useCounterStore } from '@/stores/counter'
// 在组件内部的任何地方均可以访问变量 `store` ✨
const store = useCounterStore()
</script>

完成实例创建后,仓库配置对象中配置的方法和数据即存在于调用useCounterStore方法返回的store实例上,通过store即可对仓库内容进行读写和调用:

javascript 复制代码
store.count++

setup风格的属性及方法定义

使用setup风格的配置函数:

javascript 复制代码
export const useCounterStore = defineStore('counter', () => {
  const count = ref(0)
  const name = ref('Eduardo')
  const doubleCount = computed(() => count.value * 2)
  function increment() {
    count.value++
  }

  return { count, name, doubleCount, increment }
})

setup风格配置函数的调用和配置对象一样,都是通过import引入定义的useCounterStore方法,调用后返回仓库实例对象store。

简单例子

目录结构

要使用pinia,记得在main.ts里注册:

src/main.js:

javascript 复制代码
import './assets/main.css'

import { createApp } from 'vue'
import { createPinia } from 'pinia'
import App from './App.vue'

const app = createApp(App)

app.use(createPinia())

app.mount('#app')

src/stores/user.js

javascript 复制代码
import { defineStore } from 'pinia'

export const useUserInfoStore = defineStore('user',{
  state: ()=> ({
    name:'admin',
    id:'1111',
    password:'',
  }),
  getters: {
    getUserName: (state) => {
      return state.name
    }
  },
  actions: {
    setUserPassword(value: string){
      this.password = value
    }
  }
})

src/App.vue

javascript 复制代码
<script setup lang="tsx">
import { useUserInfoStore } from '@/stores/user'

const userStore = useUserInfoStore()

console.log(userStore.name)

console.log(userStore.getUserName)

userStore.setUserPassword('123')
console.log(userStore.password)

</script>

<template>
  <div>
    hello world
  </div>
</template>

运行效果:

相关推荐
华玥作者16 小时前
[特殊字符] VitePress 对接 Algolia AI 问答(DocSearch + AI Search)完整实战(下)
前端·人工智能·ai
Mr Xu_16 小时前
告别冗长 switch-case:Vue 项目中基于映射表的优雅路由数据匹配方案
前端·javascript·vue.js
前端摸鱼匠17 小时前
Vue 3 的toRefs保持响应性:讲解toRefs在解构响应式对象时的作用
前端·javascript·vue.js·前端框架·ecmascript
sleeppingfrog17 小时前
zebra通过zpl语言实现中文打印(二)
javascript
lang2015092817 小时前
JSR-340 :高性能Web开发新标准
java·前端·servlet
好家伙VCC18 小时前
### WebRTC技术:实时通信的革新与实现####webRTC(Web Real-TimeComm
java·前端·python·webrtc
未来之窗软件服务18 小时前
未来之窗昭和仙君(六十五)Vue与跨地区多部门开发—东方仙盟练气
前端·javascript·vue.js·仙盟创梦ide·东方仙盟·昭和仙君
baidu_2474386118 小时前
Android ViewModel定时任务
android·开发语言·javascript
嘿起屁儿整18 小时前
面试点(网络层面)
前端·网络
VT.馒头19 小时前
【力扣】2721. 并行执行异步函数
前端·javascript·算法·leetcode·typescript