返回

如何优雅的捕获错误

发布时间:2023-10-29 23:55:09 134


之前的经常会出现这样的代码逻辑:

// 假设这是一个API接口调用
function userInfo () {
return new Promise((resolve, reject) => {
setTimeout(() => {
resolve({
data: {
name: '张三', age: 18
},
code: '000'
})
}, 3000)
})
}
// 在页面加载调用这个函数
async function getUserInfo () {
try {
let res = await userInfo()
console.log('正常处理...')
} catch (error) {
// 错误捕获
}
}

封装错误捕获

async function useCaptured (asyncFunc) {
try {
const res = await asyncFunc()
return [null, res]
} catch (error) {
return [error, null]
}
}

然后在任何你需要的文件中引入上面这个帮助函数,这个帮助函数的封装规则是遵循错误优先的规则,这点和node比较类似,然后函数的命名是遵循hooks的形式。

function userInfo () {
return new Promise((resolve, reject) => {
setTimeout(() => {
resolve({
data: {
name: '张三', age: 18
},
code: '000'
})
}, 3000)
})
}

async function getUserInfo () {
let [err, res] = await useCaptured(userInfo)
if (!err) {
console.log('正常处理...')
}
}

是不是很棒!!!

​​参考文章​​


特别声明:以上内容(图片及文字)均为互联网收集或者用户上传发布,本站仅提供信息存储服务!如有侵权或有涉及法律问题请联系我们。
举报
评论区(0)
按点赞数排序
用户头像
精选文章
thumb 中国研究员首次曝光美国国安局顶级后门—“方程式组织”
thumb 俄乌线上战争,网络攻击弥漫着数字硝烟
thumb 从网络安全角度了解俄罗斯入侵乌克兰的相关事件时间线
下一篇
Vue3不支持Filters过滤器 2023-10-29 20:57:58