最新消息: 关于Git&GitHub 版本控制你了解多少?
您现在的位置是:群英 > 开发技术 > web开发 >
vuex有什么用?哪些场景需要使用vuex?
PHP中文网发表于 2021-09-27 20:22 次浏览

    今天我们一起来了解一下vuex,可能很多朋友不知道vuex是什么,vuex就是一个用来管理组件之间通信的插件。vuex的使用场景也很多,例如做用户的个人信息管理模块、电商项目的购物车模块等等。下面我们就来详细的了解一下vuex吧。

    本教程操作环境:windows7系统、vue2.9.6&&vuex4.0.2版,DELL G3电脑。

    vuex是什么?

    vuex是一个用来管理组件之间通信的插件,它是一个专为【vue.js】应用程序开发的状态管理模式,它解决了组件之间同一状态的共享问题,它能够更好地在组件外部管理状态。

    为什么需要vuex?

    当多个组件依赖于同一个状态时,由于多层组件之间的嵌套使得传参数的方法变得更加复杂,另外如果使用父子组件直接饮用或者通过事件来变更和同步状态的多酚拷贝,会使得该模式变得脆弱,从而无法维护代码。

    什么时候什么情况下使用vuex?

    构建一个中大型单页应用,需要考虑到如何更好地在组件外部管理状态。

    注意:如果不是开发大型单页应用,使用vuex可能是繁琐冗余的,也就是本来很快就可以开发完成的项目,用了vuex,结果却复杂了。一般简单的store模式就可以了。

    vuex的五大属性

    state, getters, mutations, actions, modules。

    1. state:vuex的基本数据,用来存储变量

    2. geeter:从基本数据(state)派生的数据,相当于state的计算属性

    3. mutation:提交更新数据的方法,必须是同步的(如果需要异步使用action)。每个 mutation 都有一个字符串的 事件类型 (type) 和 一个 回调函数 (handler)。

    回调函数就是我们实际进行状态更改的地方,并且它会接受 state 作为第一个参数,提交载荷作为第二个参数。

    4. action:和mutation的功能大致相同,不同之处在于 ==》1. Action 提交的是 mutation,而不是直接变更状态。 2. Action 可以包含任意异步操作。

    5. modules:模块化vuex,可以让每一个模块拥有自己的state、mutation、action、getters,使得结构非常清晰,方便管理。

    vuex使用的场景:

  • 用户的个人信息管理模块;

  • 电商项目的购物车模块,每次都调用获取购物车数量的接口(前提得有),效果是实现了,但是每一次的HTTP请求,都是对浏览器性能消耗。 对比下来,用vuex的mutations进行触发,就显得更加有优势;

  • 我的订单模块,订单列表也点击取消订单,然后更新对应的订单列表,这种情况也是用Vuex,state储存一个状态,监听这个状态,变化时更新对应的列表;

  • 从订单结算页,进入选择优惠券的页面,选择优惠券的页面。如何保存选择的优惠券信息?state保存优惠券信息,选择优惠券时,mutations提交,在订单结算页,获取选择的优惠券,并更新订单优惠信息;

    现在大家对vuex是什么,以及vuex的应用等等应该都有所了解了吧。本文对vuex有详细的介绍,希望大家阅读完这篇文章能有所收获,想要了解更多请关注群英网络其它相关文章。

标签:vuex
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
相关信息推荐