Vuex中的Action

我们强调, 不要再Mutation中进行异步操作.

        但是某些情况, 我们确实希望在Vuex中进行一些异步操作, 比如网络请求, 必然是异步的. 这个时候怎么处理呢?

        Action类似于Mutation, 但是是用来代替Mutation进行异步操作的.

1、Action的基本使用

 context是什么?

context是和store对象具有相同方法和属性的对象.

也就是说, 我们可以通过context去进行commit相关的操作, 可以获取context.state.

 在Vue组件中, 如果我们调用action中的方法, 那么就需要使用dispatchn同样的, 也是支持传递payload)

具体如下图,先diapatch调用action,再在action里commit调用mutations

2、Action返回的Promise

如果我们希望,在功能函数里面执行完dispatch,dispatch的异步操作执行完成后,继续执行功能函数里面的后续操作,如何进行回调呢?这个时候就需要Promis

Action, 我们可以将异步操作放在一个Promise, 并且在成功或者失败后, 调用对应的resolvereject

参考链接:

https://www.bilibili.com/video/BV1H7411j7Mc?from=search&seid=10645859101733219162

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值