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

良精企业网站系统网站空间的权限

良精企业网站系统,网站空间的权限,广州网站建设哪家专业,龙岗网站设计一、背景 当项目如果发生报错,影响程序体验。如果能以捕获的方式得到错误信息,而且还能定位问题,这样就好了,本文介绍onErrorCaptured实现我们想要的效果。 vue2:errorCaptured。使用与vue3同理。 vue3:…

一、背景

当项目如果发生报错,影响程序体验。如果能以捕获的方式得到错误信息,而且还能定位问题,这样就好了,本文介绍onErrorCaptured实现我们想要的效果。

vue2:errorCaptured。使用与vue3同理。

vue3:onErrorCaptured。本文介绍vue3的使用。

二、简介

组合式 API:生命周期钩子-onErrorCaptured | Vue.js

错误可以从以下几个来源捕获:

1、事件处理器;2、生命周期钩子;3、setup()函数;4、侦听器;5、自定义指令钩子;6、过渡钩子;

这个钩子有三个实参:错误对象、触发该错误的组件实例,以及一个说明错误来源类型的信息字符串。

如果组件的继承链或组件链上存在多个 errorCaptured 钩子,对于同一个错误,这些钩子会被按从底至上的顺序一一调用。这个过程被称为“向上传递”,类似于原生 DOM 事件的冒泡机制。

如果组件的继承链或组件链上存在多个 errorCaptured 钩子,对于同一个错误,这些钩子会被按从底至上的顺序一一调用。这个过程被称为“向上传递”,类似于原生 DOM 事件的冒泡机制。

如果 errorCaptured 钩子本身抛出了一个错误,那么这个错误和原来捕获到的错误都将被发送到 app.config.errorHandler

errorCaptured 钩子可以通过返回 false 来阻止错误继续向上传递。即表示“这个错误已经被处理了,应当被忽略”,它将阻止其他的 errorCaptured 钩子或 app.config.errorHandler 因这个错误而被调用。

你可以在 errorCaptured() 中更改组件状态来为用户显示一个错误状态。注意不要让错误状态再次渲染导致本次错误的内容,否则组件会陷入无限循环。

这个钩子可以通过返回 false 来阻止错误继续向上传递。请看下方的传递细节介绍。

错误传递规则

 默认情况下,所有的错误都会被发送到应用级的 app.config.errorHandler (前提是这个函数已经定义),这样这些错误都能在一个统一的地方报告给分析服务。

如果组件的继承链或组件链上存在多个 errorCaptured 钩子,对于同一个错误,这些钩子会被按从底至上的顺序一一调用。这个过程被称为“向上传递”,类似于原生 DOM 事件的冒泡机制。

如果 errorCaptured 钩子本身抛出了一个错误,那么这个错误和原来捕获到的错误都将被发送到 app.config.errorHandler

errorCaptured 钩子可以通过返回 false 来阻止错误继续向上传递。即表示“这个错误已经被处理了,应当被忽略”,它将阻止其他的 errorCaptured 钩子或 app.config.errorHandler 因这个错误而被调用。

三、未使用onErrorCaptured

views/onErrorCaptured/index.vue

<template><div class="container"><div>onErrorCaptured</div><a-button type="primary" @click="testErrorCaptured()">testErrorCaptured</a-button></div>
</template>
<script setup lang="ts">
// const testErrorCaptured = ()=>{
//   console.log('name')
// }
</script>
<style scoped lang="less">
</style>

浏览器报错 

四、使用onErrorCaptured

src/app.vue

放在app.vue里边项目里的报错都能够捕获。

<script setup lang="ts">
onErrorCaptured(err => {console.log('Caught error', err)return false
})
</script>

views/onErrorCaptured/index.vue

<template><div class="container"><div>onErrorCaptured</div><a-button type="primary" @click="testErrorCaptured()">testErrorCaptured</a-button></div>
</template>
<script setup lang="ts">
// const testErrorCaptured = ()=>{
//   console.log('name')
// }
</script>
<style scoped lang="less">
</style>

浏览器打印

五、更多用途待后续发掘。 

六、欢迎交流指正,关注我,一起学习

参考链接:

【vue3】11.跟着官网学习vue3-生命周期钩子,onErrorCaptured错误捕获钩子的使用_onunmounted_我有一棵树的博客-CSDN博客

Vue 错误处理 — onErrorCaptured 钩子_lio_zero的博客-CSDN博客

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

相关文章:

  • 三合一网站建设系统html5下载教程
  • 快手刷赞网站推广软件高水平的网站建设公司
  • 阿里巴巴做国际网站多少钱建站申请范文
  • 太仓广告设计公司网站广州品牌策划公司排行榜
  • 长沙专业建网站公司哪里卖网站域名
  • 做网络销售都做什么网站网页制作模板兼职
  • 怎么用flash做视频网站网站建设部门管理制度
  • 专做海报设计的网站国外有名的网站
  • 做特色创意菜品的网站湛江网络
  • 网络建站步骤php网站后台开发教程
  • 外贸商城 网站建设学校门户网站
  • 89点班组建设网站wordpress 被挂马
  • 古建设工程造价管理协会网站宁波网站排名优化费用
  • 电子商务网站建设报价微信公众平台官方网
  • wordpress怎么做商城网站大型网站的优化方法
  • 商业网站建设的目的和意义什么是优化算法
  • 哪个平台做网站好抚顺做网站的公司
  • 商城网站建设需求文档机械加工网站模板
  • 公司想做一个网站首页怎么做网站建设和维护待遇
  • angularjs开发网站模板网站开发询价表模板下载
  • 网站建设提高信息jquery验证网站地址
  • 网站开发与网页后台开发武义建设局网站
  • 旅游企业做网站主要目的笑话网站域名
  • 网站开发用什么软件开发app如何制作(怎么自己做app)
  • 重庆家居网站制作公司南京seo公司
  • 宠物网站开发与实现结论北京制作网站公司哪家好
  • 浮梁网站建设怎么删除建站网站程序
  • 昆山公司网站制作动漫制作技术专业简历
  • 哈尔滨队网站网页美工淮安网站建设价位
  • a5站长平台大连公司