我想问一个有关 dva2 的一个问题:
这里以官方提供的user-dashboard的代码为例( https://github.com/dvajs/dva/... )
其effects:
*create({ payload: values }, { call, put }) {
yield call(usersService.create, values);
yield put({ type: 'reload' });
},
*reload(action, { put, select }) {
console.log('The reload is called...')
const page = yield select(state => state.users.page);
yield put({ type: 'fetch', payload: { page } });
},
这里 create 函数会触发一个 { type: 'reload' } 这样的 action,经过尝试会触发下面的 reload 同名函数
但这个是如何导致 下面的 reload 函数执行的呢?
看到源码使用的 put 函数:
function put(action) {
const { type } = action;
assertAction(type, 'sagaEffects.put');
return sagaEffects.put({ ...action, type: prefixType(type, model) });
}
应该主要也是 redux-saga 提供的,根据我的理解这里派发的 action 应该和其他的 effects 没有直接的调用关系(虽然dva增加了middleware使其返回Promise),比较困惑下面的 reload 是在哪里进行触发的?这个处理流程是如何的?
希望了解的同学能够指点一二,非常感谢
九州编程
相关分类