Pinia对store数据进行的订阅监听
Vue项目在开发过程中,我们需要将一些跨组件使用的的数据在pinia中进行状态管理,组件在初始化的时候我们能通过onMounted,computed,watch,watchEffect获取到存储在pinia state中的内容,有一些特殊情况,在组件初始化之后我们无法通过以上四种情况获取state中的内容,这时候我们怎么做呢?
这时候我们就需要用到$subscribe
基本的使用已经记录完毕了,本篇记录 Pinia对store数据进行的订阅监听,更直白点说,当store中的state变化到我们想要的那个值时,我们需要去做些什么,那么我们就需要用到$subscribe
1. 新建vue3项目,安装Pinia,配置Pinia,不再多说了,不会的可以看官网也可以看我前面的几篇记录文章
2. app.js---首先声明了一个state:baseUrl,写了一个action方法,用于改变baseUrl
import {defineStore} from "pinia"
const appStore = defineStore('appStore', {
state: () => ({
baseUrl: 'https://www.baidu.com/'
}),
actions: {
changeState(params) {
// console.log('接收到的参数===>', params)
this.baseUrl = params
}
}
})
export default appStore
3. 页面调用 注释写的有点多,真实的内容并没有多少
<template>
<div>
{{ baseUrl }}
</div>
<div v-show="isShow">
该我出现了
</div>
<button @click="changeData">
通过actions改变数据
</button>
</template>
<script>
import appStore from "@/store/app"
import {storeToRefs} from "pinia"
import {ref} from "vue"
export default {
name: "PiniaSubscribe",
setup() {
const store = appStore()
const {baseUrl} = storeToRefs(store)
const afterChangeUrl = 'https://www.taobao.com/'
let isShow = ref(false)
const subscribe = store.$subscribe((mutation, state) => {
/*
* mutation主要包含三个属性值:
* events:当前state改变的具体数据,包括改变前的值和改变后的值等等数据
* storeId:是当前store的id
* type:用于记录这次数据变化是通过什么途径,主要有三个分别是
* “direct” :通过 action 变化的
”patch object“ :通过 $patch 传递对象的方式改变的
“patch function” :通过 $patch 传递函数的方式改变的
*
* */
// 我们就可以在此处监听store中值的变化,当变化为某个值的时候,去做一些业务操作之类的
console.log(mutation)
console.log(state.baseUrl)
if (state.baseUrl === afterChangeUrl) isShow.value = true
else isShow.value = false
}, {detached: false}) //第二个参数options对象,是各种配置参数
//detached:布尔值,默认是 false,正常情况下,当订阅所在的组件被卸载时,订阅将被停止删除,
// 如果设置detached值为 true 时,即使所在组件被卸载,订阅依然在生效
//参数还有immediate,deep,flush等等参数 和vue3 watch的参数是一样的,多的就不介绍了,用到再看文档吧
// 停止订阅
// subscribe() //调用上方声明的变量值,示例(subscribe),即可以停止订阅
function changeData() {
store.changeState(afterChangeUrl)
}
return {
isShow,
baseUrl,
changeData
}
}
}
</script>
<script setup lang="ts">
import { watch } from 'vue';
import { mainStore } from '../store/index'
const store = mainStore()
// 监听pinia中整个state
store.$subscribe((mutation, state) => {
console.log(state);
})
// 监听pinia中整个state
watch(store.$state, (newValue, oldValue) => {
console.log(newValue,oldValue);
})
// 只监听pinia中某一个值的变化
watch(() => store.count, (newValue, oldValue) => {
console.log(newValue, oldValue);
})
</script>
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!