vuex导入_为Vuex添加同步Action

为什么要添加同步Action?

在某些操作中,如获取内存中的数据时,需要立即返回对应的值,而Vuex的Action规定了只能返回一个Promise,这时,如果我们想获取返回值就需要使用then或者await,代码就会变得不直观,而如果触发Mutation再从State获取值也是同理,所以如何能让Action不是异步的又能保持和Vuex的Action拥有一样的功能呢?

添加同步Action

首先我们先看看Vuex的Action的结构是如何的:

可以看到,action中传入了context和data,所以我们添加的同步action也需要增加这两个参数,同时将store绑定到action的this。

在index.js导入对应的模块和同步actions对象,同时导出修改过的同步action,用于mapSyncActions,并为每个同步action绑定this和注入参数。

然后,我们还要实现对应的dispatch方法和mapActions方法,来实现调用该action,在index.js同级文件夹下添加一个syncActions.js

如果要在Vuex模块中使用,只需要导入syncActions.js然后同Vuex的action调用一样即可。

若要在组件中使用,只需要同mapActions一样使用mapSyncActions即可,或者使用dispatchSync。

结语

说实在搞这个其实没啥用,因为用到的机会其实也很小,只是当初我把XK-Note重构到Vuex时,不想修改太多的代码逻辑搞出来的,本文的实例具体可以查看XK-Note。

声明: 本文采用 BY-NC-SA 协议进行授权,如无注明均为原创,转载请注明转自 青空之蓝

本文地址: 为Vuex添加同步Action

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值