Vue 中 store 基本用法

Vue 中 store 基本用法,第1张

用来管理状态,共享数据,在各个组件之间管理外部状态

第一步:项目安装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)

官方文档


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/bake/7873415.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-10
下一篇2023-04-10

发表评论

登录后才能评论

评论列表(0条)

    保存