首页 > 其他分享 >pinia的使用

pinia的使用

时间:2024-01-29 11:46:45浏览次数:22  
标签:const state pinia 使用 import useStore store

Pinia和Vuex区别

大致总结:

支持选项式api和组合式api写法
pinia没有mutations,只有:state、getters、actions
pinia分模块不需要modules(之前vuex分模块需要modules)
TypeScript支持很好
自动化代码拆分
pinia体积更小(性能更好)
如何使用Pinia

一、安装使用Pinia

1.1 安装下载

// pinia 2.1.0以上需要vue3.3支持
// vue3.3以下的可指定版本 pnpm install [email protected]
pnpm install pinia

1.2 main.ts引入

import { createPinia } from 'pinia'

app.use(createPinia())

1.3 根目录新建store/index.ts中写入

import { defineStore } from 'pinia'

export const useStore = defineStore('store', {
  state: () => {
    return {
      counter: 0,
    }
  },
  getters:{},
  actions:{}
})

1.4 组件使用

import { useStore } from '../store'
const store = useStore();

二、State

2.1 Pinia定义state数据

state: () => {
	return {
		counter: 0,
		name: 'Eduardo',
		isAdmin: true,
	}
},

2.2 组件使用pinia的state数据

import { useStore } from '../store'
const store = useStore();
let { name } = store;

2.3 组件修改pinia的state数据

本身pinia可以直接修改state数据,无需像vuex一样通过mutations才可以修改,但是上面写的let { name } = store;这种解构是不可以的,所以要换解构的方式。

import { storeToRefs } from 'pinia'
import { useStore } from '../store'
const store = useStore();
let { name }  = storeToRefs(store);
const btn = ()=>{
	name.value = '123';
}

2.4 如果state数据需要批量更新

import { storeToRefs } from 'pinia'
import { useStore } from '../store'
const store = useStore();
let { name,counter,arr }  = storeToRefs(store);
const btn = ()=>{
	//批量更新
	store.$patch(state=>{
		state.counter++;
		state.arr.push(4);
		state.name = '456';
	})
}

三、actions

actions就比较简单了,写入方法,比如我们可以让state中的某一个值+=,而且传入参数

import { defineStore } from 'pinia'
export const useStore = defineStore('storeId', {
  state: () => {
    return {
      counter: 0
    }
  },
  getters:{},
  actions:{
  	changeCounter( val ){
  		this.counter += val;
  	}
  }
})

组件上使用

import { storeToRefs } from 'pinia'
import { useStore } from '../store'
const store = useStore();
let { counter }  = storeToRefs(store);
const add = ()=>{
	store.changeCounter(10);
}

四、getters

getters和vuex的getters几乎类似,也是有缓存的机制

getters:{
  	counterPar(  ){
  		console.log(111);
  		return this.counter + 100;
  	}
 }
import { storeToRefs } from 'pinia'
import { useStore } from '../store'
const store = useStore();
let { counter, counterPar }  = storeToRefs(store);

Pinia持久化存储

一、安装插件

npm i pinia-plugin-persist --save

二、store/index.ts

import { createPinia } from 'pinia'
import piniaPluginPersist from 'pinia-plugin-persist'
 
const store = createPinia()
store.use(piniaPluginPersist)
 
export default store

三、store/user.ts


export const useUserStore = defineStore({
  id: 'user',
  state: () => {
    return {
      name: '张三'
    }
  },
  // 开启数据缓存
  persist: {
    enabled: true
  }
})

四、自定义 key

数据默认存在 sessionStorage 里,并且会以 store 的 id 作为 key。

persist: {
  enabled: true,
  strategies: [
    {
      key: 'my_user',
      storage: localStorage,
    }
  ]
}

五、持久化局部 state

默认所有 state 都会进行缓存,你能够通过 paths 指定要长久化的字段,其余的则不会进行长久化。

state: () => {
  return {
    name: '张三',
    age: 18,
    gender: '男'
  }  
},
 
persist: {
  enabled: true,
  strategies: [
    {
      storage: localStorage,
      paths: ['name', 'age']
    }
  ]
}

原文链接:https://blog.csdn.net/weixin_62765236/article/details/127448365

标签:const,state,pinia,使用,import,useStore,store
From: https://www.cnblogs.com/chaplink/p/17994159

相关文章

  • 解决使用PowerShell执行命令出现“因为在此系统上禁止运行脚本”的问题
    1、......
  • 页面中的blockShow组件展示,可进行相关的样式修改,一般月饼图搭配使用,具体根据实际来
    <template><!--这是新版的相对应的颜色列表的UI--><divclass="bllockListShow"><divclass="pieList"v-for="(item,index)indataArr":key="index"@click="clickUptown(index,item)"......
  • PROC COMPARE 使用的一些小技巧
    在SASbase中,PROCCOMPARE可以比较两个数据集的差异,实际工作中常应用在ADaM和TFL的QC中,下面介绍一些PROCCOMPARE常用的使用技巧。指定主键默认情况下,PROCCOMPARE从第一个观测开始,逐行对比两个数据集的观测。在数据集没有增减观测的情况下,这样做一般没有问题。如果......
  • HTML5 WebSocket 详解及使用
    WebSocket没用过的同学,听上去,可能觉得很难,其实很简单,本章讲解了WebSocket基本信息,以及附有代码例子WebSocket是什么?WebSocket是HTML5提供的一种在单个TCP连接上进行全双工通讯的协议。(双向通信协议)WebSocket的作用?实现客户端与服务器之间的双向通信,允许服务端主动......
  • 程序运行过程中改变按钮的文本大小,你可以使用`configure`方
    在Python的Tkinter库中,你可以通过`font`参数来设置`Button`组件的文本大小²。以下是一个简单的例子:```pythonfromtkinterimport*root=Tk()button=Button(root,text="Hello",font=("Arial",20))button.pack()root.mainloop()```在这个例子中,我们创建了一个按钮并......
  • Hutool时间相关工具类的使用
    一、CalendarUtil相关方法:1. calendar(时间):获取Calendar型对象。参数说明:时间:a. 参数为空:获取Calendar的实例对象eg:calendar.get(Calendar.MONTH)b. Date型对象:把Date转为Calendar。c. long型时间戳:转换为Calendar对象,使用当前默认时区。d. long型时间戳,Tim......
  • 自动化测试神器:Python之Pytest库入门使用
    (自动化测试神器:Python之Pytest库入门使用)本文写作思路和建议:1、本文从Python的Pytest库基本安装使用开始讲起,详细说明pytest如何操作,如何快速入门?2、同时说明了pytest的常用特性,如何在自动化测试中进行应用,达到应有的测试效率?3、建议:阅读本文基本可以掌握Pytest的用法,另外学......
  • Go语言的100个错误使用场景(一)|代码和项目组织
    目录前言1.Go:Simpletolearnbuthardtomaster1.1Go语言概述1.2简单不等于容易1.3使用Go的100个错误2.Codeandprojectorganization2.1变量屏蔽(#1)2.2没有必要的代码嵌套(#2)2.3误用init函数(#3)2.4过度使用getter&setter(#4)2.5接口污染(#5)2.6在生产侧的接口(#6......
  • 使用核模型高斯过程(KMGPs)进行数据建模
    核模型高斯过程(KMGPs)作为一种复杂的工具可以处理各种数据集的复杂性。他通过核函数来扩展高斯过程的传统概念。本文将深入探讨kmgp的理论基础、实际应用以及它们所面临的挑战。核模型高斯过程是机器学习和统计学中对传统高斯过程的一种扩展。要理解kmgp,首先掌握高斯过程的基础......
  • rsync基本使用
    参考:https://www.cnblogs.com/f-ck-need-u/p/7220009.htmlrsync官方网站:https://www.samba.org/ftp/rsync/rsync.html参数说明Local:rsync[OPTION...]SRC...[DEST]Accessviaremoteshell:Pull:rsync[OPTION...][USER@]HOST:SRC...[DEST]Push:rsync[OPT......