
第一步:项目安装vuex插件
第二步:引入vuex,并通过use方法使用它
第三步: 创建状态仓库
//创建状态仓库,注意第二个Store是大写的不能改,,state也是不能改
第四步:在main.js注入Vue实例当中
第五步:通过this.$sore.state.XXX拿到全局状态
七、Vuex的相关 *** 作
vuex状态管理的流程
view——>actions—–>mutations—–>state——>view
一、
方法一、更改 Vuex 的 store 中的状态的唯一方法是提交 mutation
在其他组件中利用commit来触发mutations函数
this.$store.commit('increase',xxx) xxx 表示传入参数,如果需要传入多个参数,将 xxx 表示成对象 {xxx1:'',xxx2:''} 方式传入,在对象内构成多个需要传入参数。
方法二:
利用actions中对mucations进行 *** 作,间接对state进行修改
利用dispatch来触发actions函数
mucations和actions两者之间区别
1、传递参数不一样,前者传递是state,后者传递是context。
2、调用的方式不一样,前者靠 this.$store.commit('xxx') 触发,后者靠 this.$store.dispatch('xxx') 触发。
3、actions可以包含异步 *** 作,但是mutation只能包含同步 *** 作
二、getters是vuex中的一个属性,主要作用于vue中的计算属性(computed)类似,用来存放一些经过修改的数值
在调用getters中的内容是使用$store.getters.函数名进行调用
总结:在工程化项目中,vuex所有内容建议和routers一样,在src中建立一个state文件夹>index.js,将vuex内容写在index.js中,再导出到main.js中。
如果打算开发一个大型的单页应用,使用vuex比较合适。它可以让页面中多个组件共享变量,即单页面中全局的变量。如果应用比较简单,可以不考虑使用vuex来管理全局变量。
注意,vuex在单页应用中生效,如果跳转到其他页面,vuex会失效(不会保存上一个页面的变量信息)。
这里注意版本对应关系 vue2/vuex3,vue3/vuex4。
这里指定版本vuex3
推荐目录结构,在src目录下新建store目录,新建index.js。
在main.js中引用
https://gitee.com/animal-fox_admin/learn-vue-web
branch:lesson4
vuex适合用于多组件共享数据的情况,多个组件都能读,也都可以改。
vuex的执行流程:
安装
使用
vuex是一个插件,所以需要Vue.use
注册了vuex,我们就可以在vue里配置store了
getters
这里多了个配置 getters ,他可以看作是基于state的computed属性。使用的方式基本如下:
同时getters还可以配置成函数,方便我们动态传参,满足一些复杂一点的场景
调用
模块化store
随着项目迭代,需求的扩展,你的store会变得越来越臃肿,建议模块化拆分store
以上就是一些对象的拼装,但是模块要放到名为modules的属性内部,store的最终结构大致如下:
模块的命名空间
默认模块的state、getter等属性都会合并到根级别,如果你希望模块有更好的封装性,避免多模块命名污染,可以配置上命名空间属性namespace:true
使用了模块命名空间后,action和getter内部常规用法只能访问本命名空间的dispatch,commit或者getter,如果要访问全局命名空间,需要使用额外的参数和配置:
模块动态注册
在 store 创建之后,你可以使用 $store.registerModule 方法注册模块
如果大多场景下,你的模块化store并不会被使用,只在你的业务流程页面中被用到,这时可以考虑在合适的生命周期节点(比如created)动态注册你的模块。同时要注意先检查模块是否已经被安装: $store.hasModule(moduleName) ,避免重复注册模块,不然会出现逻辑问题。你也可以卸载自己的模块: $store.unregisterModule(moduleName)
官方文档
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)