关于uniapp vuex store的使用心得

本文分享了如何在uniapp小程序中正确使用全局store进行状态管理,包括登录触发状态更新、错误调用方式的分析,以及如何确保组件的重新渲染。通过实例对比和大佬建议,探讨了首次空值显示和后续数据获取的问题。

今天写了一个全局store,这是在uniapp里写的,不过vue的也差不多,看文档怎么测试都不对,经过一下午终于能理解一点了,不说了,直接上代码了
这是我的store.js随便找个文件放了,记住引用的时候路径对就行了
在这里插入图片描述
main.js 里引用
在这里插入图片描述
这里相信大部分都会,主要是下面 调用
这里我是登录才更新状态的
在这里插入图片描述
而且 也 会提交Mutation
在这里插入图片描述
你会发现他会请求一次接口,同时改变store.js的state对象里面的userInfo值
我先来个错误的调用方式,当你这样写的时候
在这里插入图片描述
我的发现是错的
在这里插入图片描述
而且你会发现明显是有数据的
在这里插入图片描述
在这里插入图片描述
我的是这样的使用的
在这里插入图片描述
在这里插入图片描述
这样就可以显示出来,
问了大佬 ,大佬说是 第一次为空第二次获取到了但是没有重新渲染,不过我另一个朋友this.$store.state.userInfo.nickname这样渲染 也是可以渲染的,搞不懂,他的是uniapp H5 我的是uniapp 小程序的,有懂的大佬也可以告诉我一下,不胜感激

Uniapp使用 Vuex,可以实现全局状态管理。下面是一个简单的示例,介绍如何在 Uniapp使用 Vuex。 1. 首先,在你的项目中安装 Vuex: ```bash npm install vuex ``` 2. 在你的项目中创建一个 `store` 目录,用于存放 Vuex 相关的文件。 3. 在 `store` 目录下创建一个 `index.js` 文件,用于配置 Vuex 的核心内容。 ```javascript // store/index.js import Vue from 'vue' import Vuex from 'vuex' Vue.use(Vuex) const store = new Vuex.Store({ state: { count: 0 }, mutations: { increment(state) { state.count++ }, decrement(state) { state.count-- } }, actions: { increment(context) { context.commit('increment') }, decrement(context) { context.commit('decrement') } }, getters: { getCount(state) { return state.count } } }) export default store ``` 在上述代码中,我们定义了一个包含 `state`、`mutations`、`actions` 和 `getters` 的 Vuex store。`state` 用于存储应用的状态,`mutations` 用于修改状态,`actions` 用于提交 mutations,`getters` 用于获取状态。 4. 在主入口文件 `main.js` 中导入并挂载 Vuex store: ```javascript // main.js import Vue from 'vue' import App from './App' import store from './store' Vue.config.productionTip = false App.mpType = 'app' const app = new Vue({ store, ...App }) app.$mount() ``` 在上述代码中,我们将创建的 Vuex store 对象导入并挂载到 Vue 实例上,这样就可以在整个应用中共享该 store 中定义的状态和方法。 5. 现在,你可以在组件中使用 Vuex 了。例如,在一个组件中获取和修改状态: ```vue <template> <div> <p>Count: {{ count }}</p> <button @click="increment">Increment</button> <button @click="decrement">Decrement</button> </div> </template> <script> export default { computed: { count() { return this.$store.getters.getCount } }, methods: { increment() { this.$store.dispatch('increment') }, decrement() { this.$store.dispatch('decrement') } } } </script> ``` 在上述代码中,我们通过 `$store` 访问 Vuex store 对象,使用 `getters` 获取状态,使用 `dispatch` 提交 actions。 这样,你就可以在 Uniapp使用 Vuex 进行全局状态管理了。希望对你有所帮助!如果有任何疑问,请随时提出。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值