dva处理_umi项目中dvaeffects异常统一处理
在前端项目中使用了Ant Design,这个框架又使用了dva、umi、redux-saga。其中与后台的交互往往需要使用effects,例如*fetchColumns(_, { call, put }) {
const data = yield call(fetchColumns);
yield put({
type: 'saveColumns',
payload: data,
});
},
*fetchSessionColumns(_, { call, put }) {
const data = yield call(fetchSessionColumns);
yield put({
type: 'saveSessionColumns',
payload: data,
});
},
此时如果后台服务器返回500错误,会导致call Effect抛出异常,最终会导致generator 停止运行。
解决的方法是可以加上try catch,例如*fetchColumns(_, { call, put }) {
try{
const data = yield call(fetchColumns);
yield put({
type: 'saveColumns',
payload: data,
});
}catch (e) {
onError(e)
}
}
但是这样的话,需要每次调用时都try catch,因此需要统一异常处理。
Ant Design封装的是umi,umi封装了dva,dva封装了redux-saga。统一异常处理可以在umi中进行。官方文档中说明如下在 src 目录下新建 app.js,内容如下:export const dva = {
config: {
onError(e) {
e.preventDefault();
console.error(e.message);
},
}
};
总结
以上是生活随笔为你收集整理的dva处理_umi项目中dvaeffects异常统一处理的全部内容,希望文章能够帮你解决所遇到的问题。
- 上一篇: php实现小说字典功能_四十章 PHP
- 下一篇: git怎么上传文件到别人的仓库_Git将