根据 在组件中dispatch一个action的例子中,如果要在effects中对于param数据和当前的state数据进行再出处理,这里怎么获取state呢?采用select,如下:
export default {
namespace: 'example',
state: {num:1}, //表示当前的example中的state状态,这里可以给初始值,这里num初始为1
effects: { //这里是做异步处理的
*addByONe({ param}, { call, put,select }) { //这里使用select
const num = yield select(state => state.num) //这里就获取到了当前state中的数据num
//方式二: const num = yield select(({num}) =>num)
//方式三: const num = yield select(_ =>_.num)
let param1;
param1 = num + param; 这里就可以使用num进行操作了
yield put({
type: 'save',
num:param1
});
}
},
//用来保存更新state值 上面的put方法调用这里的方法
reducers: {
save(state, action) { //这里的state是当前总的state,这里的action包含了上面传递的参数和type
return { ...state, ...action.num }; //这里用ES6语法来更新当前state中num的值
},
},
};