Vuex的五大模块

2023年1月3日13:29:28

前言

相信大家在学习组件通信时,多个组件之间进行通信,会存在父传子,子传父,兄弟传兄弟等等情况的发生,多个组件互相通信容易造成逻辑混乱,数据不好管理,复用性差的情况,而Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化;总结一句话就是:Vuex是用来集中管理组件依赖的数据,很好的解决了组件之间通信麻烦不易维护的缺点;下面我将结合Vue.js官网带领大家深入学习Vuex的五大模块;
Vuex的五大模块

state模块

如上原理图所示,其中的state模块是用来定义和存放数据的,如果使用次数不多,可以使用$store.state.数据名去读取state中存放的数据;其中的store是Vuex模块的管理者,无论调用dispatch还是commit都需要store。多次使用建议用mapState引入,然后在computed中用…展开使用,mapState本身是一个函数,调用传递一个数组,要用哪像直接将名字写到数组里就行,他的返回值是一个对象,对象里存的就是想要用到的数据的计算属性使用:直接写this.数据名字就行;

actions模块

actions模块用于响应组件中的动作一般代码的逻辑写在actions中,比如我需要点击一个按钮500毫秒以后提交给下一个模块操作,此时可以给commit操作写在一个定时器里面,500毫秒以后再调用commit方法;

mutations模块

此模块用于修改state模块中的数据,actions模块调用commit方法就能直接将数据传到mutations模块中,mutations模块可以根据收到的数据,直接修改state模块中储存的数据;

getters模块

此模块用于对state的中存储的数据进行加工处理,有点类似于computed计算属性;

store模块

store如上原理图所示,是用于管理其它模块的,在调用dispatch和commit方法时,都需要使用$store;
dispatch
Vuex的五大模块
commit
Vuex的五大模块

写在最后

????(❁´◡`❁)您的点赞????➕评论????➕收藏⭐是作者创作的最大动力????

  • 作者:前端小二哥
  • 原文链接:https://blog.csdn.net/qq_44588612/article/details/125307271
    更新时间:2023年1月3日13:29:28 ,共 956 字。