欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 财经 > 产业 > Pinia(三): 了解和使用state

Pinia(三): 了解和使用state

2025/5/17 17:40:52 来源:https://blog.csdn.net/qq_37635012/article/details/139319745  浏览:    关键词:Pinia(三): 了解和使用state

1.state

state 就是我们要定义的数据, 如果定义 store 时传入的第二个参数是对象, 那么 state 需要是一个函数, 这个函数的返回值才是状态的初始值.这样设计的原因是为了让 Pinia 在客户端和服务端都可以工作
官方推荐使用箭头函数(()=>{ })获得更好的类型推断

import { defineStore } from 'pinia';const userStore = defineStore('user', {state: () => {return {user: {name: 'tom',age: 18},color: 'red',userList: [],}}
})

2.TypeScript

可以定义 interface 来标记类型

import { defineStore } from 'pinia';interface UserInfo {name: string;age: number;
}export const userStore = defineStore('user', {state: () => {return {color: 'red' as string,userList: [] as UserInfo[],user: {name: 'tom',age: 18} as UserInfo | null}}
})

3.访问 state

默认可以直接通过 store 实例访问和修改 state.

const user = userStore();
function changeColor() {user.color = 'black'
}
function changeAge() {user.user.age++;
}

4.重置 state

调用 store 的 $reset()

function resetStore() {user.$reset();
}

5.修改 state

除了直接通过 store 修改 state, 还可以调用 store 的 $patch 方法. 这个方法允许一次进行多处修改

function patchChange() {user.$patch({color: 'skyblue',user: {age: user.user.age + 10}})
}

但是这种语法有时会很麻烦, 比如我们想要对数组进行增删时, 这种语法会要求创建一个新的数组. 所以 $patch 方法可以接收一个函数为参数.

function patchChangeFunction() {user.$patch((state) => {state.userList.push({ name: 'mike', age: 19 });state.user.age++;state.color = 'pink';});
}

也直接通过 store 的 $state 属性修改 state, 因为其内部会调用 $patch

function stupidChange() {user.$state = {color: 'hahha'}// 实际上内部调用了// user.$patch({ color: 'hahha' })
}

6.订阅状态

我们可以通过 store 的 $subscribe 方法侦听 state 的改变. 使用 $subscribe 而不是 watch() 的好处是 $subscribe 总是在 state 修改之后执行一次.

user.$subscribe((mutation, state) => {console.log('mutation', mutation);
})

在这里插入图片描述
在这里插入图片描述

const stopSubscribeFunc = user.$subscribe((mutation, state) => {console.log('mutation', mutation);console.log('state', state);
})
function stopSubscribe() {stopSubscribeFunc()
}

如果在组件内调用 store.$subscribe(), 那么组件卸载时会自动清理定于, 除非将 detached 设置为 true

user.$subscribe((mutation, state) => {// do something...
}, {detached: true
})

如果要实现保存数据到 localStorage, 可以使用 watch

//main.js里
const pinia = createPinia();
app.use(pinia);watch(pinia.state,(state) => {console.log(state)localStorage.setItem('piniaState', JSON.stringify(state));},{deep: true,immediate: true}
)

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词