Pinia使用state、getters、actions

4/30/2023 Pinia

# 一、安装使用 Pinia

1.1 安装下载

yarn add pinia
# or with npm
npm install pinia
1
2
3

1.2 main.js 引入

import { createPinia } from "pinia";

app.use(createPinia());
1
2
3

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

import { defineStore } from "pinia";

export const useStore = defineStore("storeId", {
  state: () => {
    return {
      counter: 0,
    };
  },
  getters: {},
  actions: {},
});
1
2
3
4
5
6
7
8
9
10
11

1.4 组件使用

<script setup>
  import {useStore} from '../store' const store = useStore();
</script>
1
2
3

# 二、State

2.1 Pinia 定义 state 数据

import { defineStore } from "pinia";

export const useStore = defineStore("storeId", {
  state: () => {
    return {
      counter: 0,
      name: "Eduardo",
      isAdmin: true,
    };
  },
  getters: {},
  actions: {},
});
1
2
3
4
5
6
7
8
9
10
11
12
13

2.2 组件使用 pinia 的 state 数据

<template>
	<div>
		<h1>A组件</h1>
		{{ name }}
	</div>
</template>

<script setup>
import { useStore } from '../store'
const store = useStore();
let { name } = store;
</script>
1
2
3
4
5
6
7
8
9
10
11
12

2.3 组件修改 pinia 的 state 数据

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

<template>
	<div>
		<h1>A组件</h1>
		{{ name }}
		<button @click='btn'>按钮</button>
	</div>
</template>
<script setup>
import { storeToRefs } from 'pinia'
import { useStore } from '../store'
const store = useStore();
let { name }  = storeToRefs(store);
const btn = ()=>{
	name.value = '123';
}
</script>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16

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

store/index.js

import { defineStore } from "pinia";

export const useStore = defineStore("storeId", {
  state: () => {
    return {
      counter: 0,
      name: "Eduardo",
      arr: ["a", "b", "c"],
    };
  },
  getters: {},
  actions: {},
});
1
2
3
4
5
6
7
8
9
10
11
12
13

组件代码

<template>
	<div>
		<h1>A组件</h1>
		{{ name }}
		{{ counter }}
		{{ arr }}
		<button @click='btn'>按钮</button>
	</div>
</template>
<script setup>
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';
	})
}
</script>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23

***使用$patch 进行批量更新

# 三、actions

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

import { defineStore } from 'pinia'

export const useStore = defineStore('storeId', {
  state: () => {
    return {
      counter: 0
    }
  },
  getters:{},
  actions:{
  	changeCounter( val ){
  		this.counter += val;
  	}
  }
})
<template>
	<div>
		<h1>A组件</h1>
		{{ counter }}
		<button @click='add'>10</button>
	</div>
</template>
<script setup>
import { storeToRefs } from 'pinia'
import { useStore } from '../store'
const store = useStore();
let { counter }  = storeToRefs(store);
const add = ()=>{
	store.changeCounter(10);
}
</script>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31

# 四、getters

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

import { defineStore } from 'pinia'

export const useStore = defineStore('storeId', {
  state: () => {
    return {
      counter: 0,
    }
  },
  getters:{
  	counterPar(  ){
  		console.log(111);
  		return this.counter + 100;
  	}
  },
  actions:{}
})
<template>
	<div>
		{{ counterPar }}
		{{ counterPar }}
		{{ counterPar }}
		<h1>A组件</h1>
		{{ counter }}
	</div>
</template>
<script setup>
import { storeToRefs } from 'pinia'
import { useStore } from '../store'
const store = useStore();
let { counter, counterPar }  = storeToRefs(store);
</script>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
Last Updated: 11/8/2023, 10:40:28 AM