目录
读state
state?
?写state
?方式一:【修改单个数据时推荐】
?方式二:$patch({})? ?【不推荐】
方式三:$patch((state)=>{})? ?【修改多个数据时推荐】
方式四:$state
?方式五:action? 【修改多个数据时推荐】?
action
同步
异步
getters
内置api函数
$reset()
$subscribe
$onAction
下载:
npm i -S pinia
main.js中引入pinia:?
data:image/s3,"s3://crabby-images/29c62/29c62ae1a6239ef0e379994cc1669c5e9c279904" alt=""
import { createApp } from 'vue'
import './style.css'
import App from './App.vue'
import { createPinia } from "pinia"
createApp(App).use(createPinia()).mount('#app')
读state
data:image/s3,"s3://crabby-images/cce2a/cce2ac9d220fd5039e0a8acd100797949e1eb44c" alt=""
data:image/s3,"s3://crabby-images/1b842/1b842a444eba911fe0311e5018d4599270bb1a2e" alt=""
import { defineStore } from "pinia";
export const useTestStore = defineStore('Test', {
state: () => {
return {
user: '张三',
age: 33
}
},
getters: {
},
actions: {
}
})
state?
?写state
?方式一:【修改单个数据时推荐】
data:image/s3,"s3://crabby-images/2e5d3/2e5d338be14cdae3fca8fe845d6a8f12bb07f530" alt=""
?方式二:$patch({})? ?【不推荐】
data:image/s3,"s3://crabby-images/db4ef/db4ef1d047ddcaa39671a32576e5324a6608c737" alt=""
方式三:$patch((state)=>{})? ?【修改多个数据时推荐】
data:image/s3,"s3://crabby-images/14a9a/14a9acc04cb741feca8b913f9aa7e0228d173ce3" alt=""
方式四:$state
data:image/s3,"s3://crabby-images/e2d62/e2d62633a9b424c513c62bc134fb24955c0a46bc" alt=""
?方式五:action? 【修改多个数据时推荐】?
data:image/s3,"s3://crabby-images/3bc68/3bc689cd8e369e35ff25ade4cc86c7db58a4f488" alt=""
state解构-storeToRefs
需要使用storeToRefs()才能是响应式
data:image/s3,"s3://crabby-images/09543/0954356d24cf9984d661163876b39de97926ca6a" alt=""
<template>
<div>
<p>user: {{ user }}</p>
<p>age: {{ age }}</p>
<p>Test.user {{ Test.user }}</p>
<p>Test.age {{ Test.age }}</p>
</div>
<button @click="change">修改</button>
</template>
<script setup>
import { storeToRefs } from "pinia";
import { useTestStore } from "./store";
const Test = useTestStore();
let { user, age } = storeToRefs(Test);
function change() {
user.value = "李四";
age.value++;
}
</script>
<style scoped>
</style>
?
action
同步
data:image/s3,"s3://crabby-images/6ea4b/6ea4b8cecf81c0d33c68a93a8da134e6e4bfdbc7" alt=""
异步
data:image/s3,"s3://crabby-images/2509d/2509dae6730c70cf3987fd3aacf9dde9c9337c6e" alt=""
getters
data:image/s3,"s3://crabby-images/524b8/524b8bdd72c3ac77b631616ccdf98a106bcf7a14" alt=""
内置api函数
$reset()
state重置为初始化状态
data:image/s3,"s3://crabby-images/38eec/38eec8850f4fae505b6640a7aa1cc5ae0e92c97b" alt=""
$subscribe
state中的值一改变就会触发
data:image/s3,"s3://crabby-images/fb1f1/fb1f1cc430a4ee8e2f70ba25f565b6cfefd99fdc" alt=""
data:image/s3,"s3://crabby-images/c1a7a/c1a7a1f915274b96927cae4e5667773254d239e3" alt=""
$onAction
$onAction函数接受一个回调函数,该回调函数内部的代码会先于actions函数调用前执行
?after钩子函数会在actions中的函数被调用后执行
data:image/s3,"s3://crabby-images/c5e2b/c5e2bf368fd4fbda9d57a7419b0314b3f256b42a" alt="" ?
|