三、解决方案
3.1 使用 catch 方法处理 Promise 的错误
在 Promise 中,catch
方法被用来处理错误。如果 Promise 变成了rejected
状态,那么catch
方法会被调用。
const promise = new Promise((resolve, reject) => { reject('error'); }).catch((error) => { console.log(error); });
在上面代码中,代码添加了catch
方法来捕获 Promise 的错误。如果 Promise 的状态变成rejected
,那么catch
方法会被调用,我们就可以在里面处理这个错误。
在我的项目中的解决方式。
index.js 代码:
export async function addAlarmRule(data) { const res = await request({ url: '/device/rule', method: 'post', data: data }); if(res.code === 200) { return res.data; } return Promise.reject(new Error(res.message)); }
index.vue 代码:
/** 提交按钮 */ submitForm: function() { this.$refs['form'].validate(valid => { if(valid) { if(this.form.ruleId !== undefined) { updateAlarmRule(this.form).then(response => { this.$modal.msgSuccess('修改成功'); this.open = false; this.reload(); }).catch((e) => { this.$message.error(e.message); }); }else { addAlarmRule(this.form).then(response => { this.$modal.msgSuccess('新增成功'); this.open = false; this.reload(); }).catch((e) => { this.$message.error(e.message); }); } } }); }
3.2 使用 async/await 处理 Promise 的错误
如果我们在代码上不方便使用catch
方法或者不能使用catch
方法处理 Promise 的错误,我们可以使用async/await
语法糖来捕获 Promise 的错误。
async function asyncFunction() { try { const promise = new Promise((resolve, reject) => { reject('error'); }); const result = await promise; } catch (error) { console.log(error); } }
在上述示例中,将 Promise 的代码放在一个 async 函数中,并使用await
关键字等待 Promise 对象。如果 Promise 变成了rejected
状态,try/catch 将会捕获这个错误并进行处理。
3.3 全局异常处理
使用 window.addEventListener(‘unhandledrejection’, callback)处理所有未处理错误,如果应用程序中有很多 Promise,我们可以使用 window.addEventListener(‘unhandledrejection’, callback)来处理所有未处理错误。
window.addEventListener('unhandledrejection', (event) => { console.log(event.reason); });
四、总结
在进行异步编程时,使用 Promise 时常会遇到一个常见的错误类型,即Uncaught(in promise) error
。这种错误通常是因为未处理 Promise 错误所导致的。为了解决这种错误类型,在大多数情况下可以采用catch
方法或async/await
语法糖。当应用程序中存在多个 Promise 时,可以利用window.addEventListener('unhandledrejection', callback)
来处理所有未处理的错误。因此,根据代码的具体情况,来采用不同的处理方法。