Vue.js中的全局错误处理函数errorHandler用法

 更新时间:2024年06月05日 14:48:15   作者:小新-alive  
这篇文章主要介绍了Vue.js中的全局错误处理函数errorHandler用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

Vue.js全局错误处理函数errorHandler

在 Vue.js 中,errorHandler 函数是全局错误处理函数,用于捕获应用程序中未被捕获的错误。

你可以通过定义 errorHandler 函数来自定义全局错误处理逻辑。

语法

Vue.config.errorHandler = function (err, vm, info) {
  // 错误处理逻辑
};

errorHandler 函数接收三个参数:

  • err:表示错误对象,包含有关错误的详细信息,如错误消息、堆栈跟踪等。
  • vm:表示引发错误的 Vue 组件实例。通过访问该实例,你可以获取组件的状态、数据和方法。
  • info:提供有关错误的额外信息,通常是一个字符串,描述了错误发生的位置或上下文。

示例:

Vue.config.errorHandler = function (err, vm, info) {
  // 错误处理逻辑
  console.error('全局错误处理:', err, vm, info);
};

在上述示例中,errorHandler 函数被定义为一个全局错误处理函数。当应用程序中的任何组件抛出未被捕获的错误时,该函数将被调用。你可以在该函数中编写逻辑来处理错误,如记录错误、显示错误提示、进行错误恢复等。

需要注意的是,如果你在组件中定义了 errorCaptured 钩子函数来捕获错误,那么该组件的 errorCaptured 钩子函数将优先于全局的 errorHandler 函数被调用。

局错误处理函数errorHandler常见的使用场景

  • 捕获和记录错误:你可以使用 errorHandler 来捕获应用程序中未被捕获的错误,并将其记录到日志中或发送给远程错误跟踪服务。这样可以帮助你及时发现和解决潜在的问题。
  • 显示错误提示:当应用程序中出现错误时,你可以使用 errorHandler 来显示用户友好的错误提示。例如,你可以通过通知、弹窗或类似的方式向用户展示错误信息,以提供更好的用户体验。
  • 错误恢复和回退:在某些情况下,当应用程序遇到错误时,你可能希望进行错误恢复或回退操作。通过在 errorHandler 中执行相应的逻辑,你可以尝试修复错误或回到应用程序的先前状态。
  • 上报错误统计:除了记录错误,你还可以使用 errorHandler 来进行错误统计和分析。通过收集和汇总应用程序中的错误信息,你可以了解常见错误类型、发生频率等信息,从而进行性能优化和错误预防。
  • 处理异步错误:在异步操作中,错误通常需要手动捕获和处理。在 errorHandler 中,你可以统一处理异步操作中出现的错误,避免它们被静默丢失。

Vue errorHandler异常捕获

异常捕获介绍

1.在日常前端开发中对于异常监控的方式可以采用 window.onerror 方式进行监听

	window.onerror = function(message, source, lineno, colno, error) {
	 	// message:错误信息(字符串)
		// source:发生错误的脚本URL
		// lineno:发生错误的行号
		// colno:发生错误的列号
		// error:Error对象
	}
	//或者
	window.addEventListener('error', function(e) { 
	  console.log(e)
	  console.log(e.target)
	})

2.在vue中需要使用errorHandler方法

onerror方法无法捕获Vue组件信息

	Vue.config.errorHandler = function (err, vm, info) {
	  // err: 具体错误信息
	  // vm: 当前错误所在的Vue实例
	  // info: 错误所在的生命周期钩子
	}

errorHandler实际应用

针对项目中错误的js语法和接口请求报错进行捕获,需要注意的是接口捕获需要手动捕获 

1.在main.js中注册

//因为接口报错需要手动捕获 创建公用方法
const errorHandler = (err, vm, info) => {
	if(err.isAxiosError){
		//axios请求错误
	}else{
		//js语法错误
		console.log('err:'err.toString())
	}
}
//调用
Vue.config.errorHandler = errorHandler
//axios手动捕获使用 绑定 prototype
Vue.prototype.$throw = (error) => errorHandler(error, this)

2.axios错误捕获

在封装好的axios请求中进行错误响应捕获,将错误信息交给 errorHadaler 函数进行处理

Vue.$throw(error)
//或 
Vue.prototype.$throw(error)

对于error信息的解析

1.通过Json.stringify()对err进行序列化

const errorHandler = (err, vm, info) => {
	if(err.isAxiosError){
		//axios请求错误为手动捕获 不需要进行解析处理 
	}else{
		const errJson = JSON.stringify(err, Object.getOwnPropertyNames(err), 2)
		console.log(JSON.parse(errJson ))
	}
}

2.通过error-stack-parser解析error堆栈

安装方式:

npm install error-stack-parser

yarn add error-stack-parser

//引入error-stack-parser
import ErrorStackParser from 'error-stack-parser'
const errorHandler = (err, vm, info) => {
	if(err.isAxiosError){
		//axios请求错误为手动捕获 不需要进行解析处理 
	}else{
		const errJson = ErrorStackParser.parse(err)[0]
		console.log(errJson)
		//通过fileName截取页面名称
		const fileName = stackInfo.fileName.match(/src.*?.vue/g)[0]
		console.log(fileName)
	}
}

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • vue-cli+webpack项目打包到服务器后,ttf字体找不到的解决操作

    vue-cli+webpack项目打包到服务器后,ttf字体找不到的解决操作

    这篇文章主要介绍了vue-cli+webpack项目打包到服务器后,ttf字体找不到的解决操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-08-08
  • Vue利用AJAX请求获取XML文件数据的操作方法

    Vue利用AJAX请求获取XML文件数据的操作方法

    在现代Web开发中,从前端框架到后端API的交互是必不可少的一部分,Vue.js作为一个轻量级且功能强大的前端框架,支持多种方式与服务器通信,从而获取或发送数据,本文将详细介绍如何在Vue.js项目中使用AJAX请求来获取XML格式的数据,需要的朋友可以参考下
    2024-09-09
  • 在vue中实现给每个页面顶部设置title

    在vue中实现给每个页面顶部设置title

    这篇文章主要介绍了在vue中实现给每个页面顶部设置title,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-07-07
  • Vue项目打包到服务器后请求接口报错404的解决

    Vue项目打包到服务器后请求接口报错404的解决

    这篇文章主要介绍了Vue项目打包到服务器后请求接口报错404的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-05-05
  • Vue登录注册并保持登录状态的方法

    Vue登录注册并保持登录状态的方法

    这篇文章主要介绍了Vue登录注册并保持登录状态的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-08-08
  • vue v-for循环重复数据无法添加问题解决方法【加track-by=''索引''】

    vue v-for循环重复数据无法添加问题解决方法【加track-by=''索引''】

    这篇文章主要介绍了vue v-for循环重复数据无法添加问题解决方法,结合实例形式分析了vue.js通过在v-for循环中添加track-by='索引'解决重复数据无法添加问题相关操作技巧,需要的朋友可以参考下
    2019-03-03
  • vue2+element-ui使用vue-i18n进行国际化的多语言/国际化详细教程

    vue2+element-ui使用vue-i18n进行国际化的多语言/国际化详细教程

    这篇文章主要给大家介绍了关于vue2+element-ui使用vue-i18n进行国际化的多语言/国际化的相关资料,I18n是Vue.js的国际化插件,项目里面的中英文等多语言切换会使用到这个东西,需要的朋友可以参考下
    2023-12-12
  • vue如何利用axios调用后台api接口

    vue如何利用axios调用后台api接口

    这篇文章主要介绍了vue如何利用axios调用后台api接口问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-07-07
  • 利用WebStorm创建一个Vue项目的完整步骤

    利用WebStorm创建一个Vue项目的完整步骤

    WebStorm是一个非常适合学习和开发Vue项目的集成开发环境,下面这篇文章主要给大家介绍了关于利用WebStorm创建一个Vue项目的完整步骤,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2024-06-06
  • vue3.0和vue2.0的区别详细讲解

    vue3.0和vue2.0的区别详细讲解

    vue经历从2.0到3.0更新之后,简⽽⾔之就是变得更轻更快,使⽤起来更加⽅便,下面这篇文章主要给大家介绍了关于vue3.0和vue2.0区别的相关资料,需要的朋友可以参考下
    2023-10-10

最新评论