dispatch js实现_dva.js(and design)实现dispatch的回调函数

这篇博客探讨了如何在 DVA 框架的 @2 版本和 @1 版本中处理回调函数和 Promise。在 DVA@2 中,可以通过将回调函数作为 dispatch 的 payload 参数来实现,而在 model 的 effects 中处理回调。在 DVA@1 中,可以利用 Promise 的 then 方法,将 resolve 作为 dispatch 的 payload,并在 model 的 effects 中通过 resolve 返回数据。这两种方式都允许在异步操作完成后执行相应的逻辑。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、在dispatch中使用callback

在dva@2中实现回调可以将回调函数作为参数dispatch:

dispatch({

type: 'model/fetch',

payload: {

resolve,

id: userId,

},

callback: res => {

console.log(res);

}

})

然后在model的effects中这样写:

*fetch({ payload, callback }, {call}) {

const response = yield call(services.fetch, payload);

if (response.code === 0) {

yield put({

type: 'reload',

payload: response,

});

if (callback) callback(response);

}

二、在dispatch中使用then

如果在dva@1中要实现回掉可以用Promise实现:

new Promise((resolve) => {

dispatch({

type: 'model/fetch',

payload: {

resolve,

id: userId,

}

})

}).then((res) => {

console.log(res);

})

然后在model的effects中这样写:

...

*fetch({ payload }, { call }) {

const { resolve } = payload;

const { data } = yield call(services.fetch, payload);

if (data.code === 0) {

// 通过resolve返回数据,返回的数据将在Promise的then函数中获取到

!!resolve && resolve(data.data);

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值