当前位置: 首页 > news >正文

没有备案的网站百度不收录中国交通建设集团有限公司官网

没有备案的网站百度不收录,中国交通建设集团有限公司官网,企业网站不付服务费应该怎么做,定制品牌排行榜前十名前言 📫 大家好,我是南木元元,热爱技术和分享,欢迎大家交流,一起学习进步! 🍅 个人主页:南木元元 目录 背景 js中的try...catch try...catch运行机制 js的事件循环机制 try...c…

前言

 📫 大家好,我是南木元元,热爱技术和分享,欢迎大家交流,一起学习进步!

 🍅 个人主页:南木元元


目录

背景

js中的try...catch

try...catch运行机制

js的事件循环机制

try...catch无法捕获异步错误的原因

解决方法

结语


背景

之前面某物的时候,遇到了一个有关try...catch的问题,让我印象深刻,这里来记录分享一下。

面试官:下面代码有什么问题吗?

示例1:

try {setTimeout(() => {throw new Error('err');}, 200);
} catch (err) {console.log(err);
}

示例2:

try {Promise.resolve().then(() => {throw new Error('err');});
} catch (err) {console.log(err);
}

第一反应是,这不就是一个普通的try...catch捕获错误吗?但其实是有坑在里面的。

js中的try...catch

js中的try...catch是平时写代码时经常会使用的,它可以捕获代码中的异常并防止应用程序崩溃

try {// 可能会抛出异常的代码
} catch(error) {// 处理所有异常的代码
}

但try...catch并不能捕获所有的异常,这就需要了解try...catch的运行机制,这样才能保证我们合理地去使用它。

try...catch运行机制

当程序运行到try...catch里面时:

  • 如果未报错,则会忽略catch中的代码
  • 若报错,则不执行try报错内容后面的代码,转而执行catch中的代码

总结一下,能被try...catch捕捉到的异常,必须是在报错的时候,线程执行已经进入try...catch 代码块,且处在 try...catch 里面,这个时候才能被捕捉到。

js的事件循环机制

js是单线程语言,事件循环是js的执行机制。

  1. 所有同步任务都在主线程上执行,形成一个执行栈
  2. 在执行同步任务的时候,如果遇到了异步事件,会将该任务挂起,继续执行同步任务,当异步事件执行完后(如定时器到时,ajax请求返回),再将对应的回调加入到一个任务队列中等待执行,任务队列可以分为宏任务队列和微任务队列
  3. 当执行栈中的同步任务执行完毕后,会执行所有微任务,清空微任务队列
  4. 当执行完所有微任务后,再去执行宏任务队列中的下一个宏任务,不断循环,直到所有任务都完成。

这一套流程,就是事件循环。

错误原因

现在回到上述代码,其实就能够明白存在的问题是try...catch无法捕获异步错误

try...catch是同步执行的,而setTimeout和Promise.resolve()一个是宏任务,一个是微任务,都是异步任务,等到setTimeout和Promise.resolve()里面的事件进入到事件队列的时候,主线程已经离开了try...catch,所以try...catch无法捕获异步错误。

解决方法

只需在同步任务中使用try...catch即可,利用Promise和async/await的内在能力。

对于第一个示例:

new Promise((resolve, reject) => {setTimeout(() => {try {throw new Error('err');} catch (err) {reject(err);}}, 200); 
})
.then(() => {// 处理成功执行的情况
})
.catch((err) => {console.log(err); // 错误在这里被捕获
});

对于第二个示例:

// 方法一:使用Promise链式调用
Promise.resolve().then(() => {throw new Error('err');}).catch((err) => {console.log(err); // 错误在这里被捕获});// 方法二:使用async/await
async function handleError() {try {await Promise.resolve().then(() => {throw new Error('err');});} catch (err) {console.log(err); // 错误在这里被捕获}
}handleError();

结语

因此,在代码中不要再随便写try...catch了,异步错误是无法被捕获的,而且像Promise有它自己的异常捕获方法,比try...catch更好用。

🔥如果此文对你有帮助的话,欢迎💗关注、👍点赞、⭐收藏、✍️评论,支持一下博主~ 

http://www.yayakq.cn/news/480746/

相关文章:

  • 电子商务网站设计要求网络营销怎么做?
  • 如何用服务器代替空间做网站游戏开发app
  • 网站域名跳转wordpress怎么登陆ftp
  • 网站备案容易吗各省网站备案时长
  • 常德房产网百度爱采购优化排名软件
  • 不限关键词做网站平台wordpress后台慢
  • 旧金山网站建设福田做棋牌网站建设哪家技术好
  • 做网站的公司怎么找客户wordpress 代码 转义
  • 重庆建网站有哪些新型网站设计
  • 网站开发说明书网站价格表
  • 四川省信用建设促进会网站厦门外贸网站建设报价
  • 黄山找人做网站wordpress 4.5.3 ueditor
  • 私募股权基金网站建设做dhl底单的网站是 什么
  • 免费做网站哪里有响应式网站模板怎么做
  • 苏州制作企业网站公司网页制作工具知乎
  • 东莞网站建设公司注册建设门户网站所需
  • 上海网站设计首选刻公司企业宣传片的拍摄
  • 九江建网站报价企业网站创建小结
  • 冒充it男给某网站做修复米拓建站免费模板
  • 网站建设如何算成本京东购物app下载安装
  • 网站素材包括哪些传媒公司网站建设策划
  • 网站排名首页前三位网站开发 制作阶段的说课稿
  • 免费申请网站空间泉州有那些网站建设公司
  • 太原百度网站排名优化做哪些网站可以赚钱的
  • 永兴县网站建设哪家好金寨县住房和城乡建设部网站
  • 龙泉做网站哪家好网站后台编辑技巧
  • 网站的软文 怎么做推广方案静态网站开发语言
  • 做奥数题网站网络认证工程师
  • 烟台网站建设推广江西 网站制作
  • 网站平台建设方案的难点重点wordpress页面显示什么意思