vue3.0零基础入门(快速掌握Vue3.0中如何上手Vuex状态管理)
vue3.0零基础入门
快速掌握Vue3.0中如何上手Vuex状态管理Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。Vuex 也集成到 Vue 的官方调试工具 devtools,提供了诸如零配置的 time-travel 调试、状态快照导入导出等高级调试功能。
如果您不打算开发大型单页应用,使用 Vuex 可能是繁琐冗余的。确实是如此——如果您的应用够简单,您最好不要使用 Vuex。一个简单的 store 模式就足够您所需了。但是,如果您需要构建一个中大型单页应用,您很可能会考虑如何更好地在组件外部管理状态,Vuex 将会成为自然而然的选择。
由于 Vuex 的状态存储是响应式的,从 store 实例中读取状态最简单的方法就是在计算属性中返回某个状态:
import { computed } from 'vue' import { useStore } from 'vuex' export default { setup () { const store = useStore() return { count: computed(() => store.state.count) } } }
Vuex 允许我们在 store 中定义“getter”(可以认为是 store 的计算属性)。就像计算属性一样,getter 的返回值会根据它的依赖被缓存起来,且只有当它的依赖值发生了改变才会被重新计算。
import { computed } from 'vue' import { useStore } from 'vuex' export default { setup () { const store = useStore() return { double: computed(() => store.getters.double) } } }
更改 Vuex 的 store 中的状态的唯一方法是提交 mutation。Vuex 中的 mutation 非常类似于事件:每个 mutation 都有一个字符串的 事件类型 (type) 和 一个 回调函数 (handler)。这个回调函数就是我们实际进行状态更改的地方,并且它会接受 state 作为第一个参数:
const store = createStore({ state: { count: 1 }, mutations: { increment (state) { state.count++ } } })
你不能直接调用一个 mutation handler。这个选项更像是事件注册:“当触发一个类型为 increment 的 mutation 时,调用此函数。”要唤醒一个 mutation handler,你需要以相应的 type 调用 store.commit 方法:
store.commit('increment')
Action 类似于 mutation,不同在于:
Action 提交的是 mutation,而不是直接变更状态。
Action 可以包含任意异步操作。
const store = new Vuex.Store({ state: { count: 0 }, mutations: { increment (state) { state.count++ } }, actions: { increment (context) { context.commit('increment') } } })
Action 通过 store.dispatch 方法触发:
store.dispatch('increment')
由于使用单一状态树,应用的所有状态会集中到一个比较大的对象。当应用变得非常复杂时,store 对象就有可能变得相当臃肿。
为了解决以上问题,Vuex 允许我们将 store 分割成模块(module)。每个模块拥有自己的 state、mutation、action、getter、甚至是嵌套子模块——从上至下进行同样方式的分割:
const moduleA = { state: () => ({ ... }), mutations: { ... }, actions: { ... }, getters: { ... } } const moduleB = { state: () => ({ ... }), mutations: { ... }, actions: { ... } } const store = createStore({ modules: { a: moduleA, b: moduleB } })
当刷新页面,项目重新加载,vuex 会重置,所有状态回到初始状态,使用 vuex-persistedstate 可以避免这种情况。
1、安装
npm install --save vuex-persistedstate
2、使用
import Vuex from "vuex"; import createPersistedState from "vuex-persistedstate"; const store = new Vuex.Store({ plugins: [createPersistedState()], });
以上就是Vue3.0中如何快速上手Vuex状态管理的详细内容,更多关于Vuex状态管理的资料请关注开心学习网其它相关文章!
- vuex中action的值怎么接(vuex中Getter的用法详解)
- vue中的mapgetter优势(vuex 中辅助函数mapGetters的基本用法详解)
- vuex存取修改数据流程(vuex数据持久化的两种实现方案)
- vue3.0零基础入门(快速掌握Vue3.0中如何上手Vuex状态管理)
- vuex原理及使用方法(Vuex状态机的快速了解与实例应用)
- vuex数据持续化(Vuex数据持久化实现的思路与代码)
- vuex怎么使用数据(vuex的辅助函数该如何使用)
- vuex-table行列转换效果(vue3+el-table实现行列转换)
- vue编程加入购物车(vuex实现简单的购物车功能)
- vue-cli请求数据的方式(vue-cli配置使用Vuex的全过程记录)
- 清华大学难考吗(清华大学考研录取分数线)
- 观花盆栽佛肚竹盆景制作及养护(观花盆栽佛肚竹盆景制作及养护)
- 春天养佛肚竹,做好这几件事,叶绿根壮寓意好 越养越旺家(春天养佛肚竹做好这几件事)
- 律界衣品最好,时尚圈学识数高,41岁的Amal堪称现实版的傲骨贤妻(时尚圈学识数高)
- 刘智泰确认出演《Good Wife》 担纲男一号(刘智泰确认出演Good)
- 《傲骨之战》剧终 律政女魔头Diane,为什么是大女主天花板(傲骨之战剧终律政女魔头Diane)
热门推荐
- php异常和错误区别(PHP批斗大会之缺失的异常详解)
- python配合docker(Docker构建python Flask+ nginx+uwsgi容器)
- docker安装部署及使用(docker在linux上的安装部署实例讲解)
- dedecms图片延迟加载(dedecms获取图片集多张图片实现方法循环输出)
- mysql常用数据模型(MySQL数据库基于sysbench实现OLTP基准测试)
- 阿里云电脑收费标准是多少(阿里云主机最便宜的多少钱一年?)
- 远程给docker容器执行命令(Docker命令让普通用户能够执行的实现)
- nginx最新配置(配置nginx 重定向到系统维护页面)
- python创建一个xls文件(Python XlsxWriter模块Chart类用法实例分析)
- html5video怎么用(html5视频媒体标签video的使用方法及完整参数说明详解)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9