vue监听页面上的报错信息,window.onerror和window.addEventListener(‘error‘)的区别

前言:

      监听页面上的报错信息

项目中使用:判断路径上有没有这个版本号...具体内容可根据实际情况来

const asyncVersion = '20210128'
window.addEventListener('error', handleListenerError, true);
    function handleListenerError (eventErr){
      if (eventErr.srcElement.localName.includes('link' || 'script') && !window.location.href.includes('version=' + asyncVersion)) {
        // alert('因版本更新,页面需重新载入,请核对当次操作数据');
        window.location.href= window.location.host + window.location.pathname + '?version=' + VUE_APP_Version
      }
      eventErr.preventDefault()
    }

更多:

window.onerror

window.onerror是一个全局变量,默认值为null。当有js运行时错误触发时,window会触发error事件,并执行window.onerror()。onerror可以接受多个参数。

window.onerror = function(message, source, lineno, colno, error) { ... }

函数参数:

*   message:错误信息(字符串)。可用于HTML onerror=""处理程序中的event。
*   source:发生错误的脚本URL(字符串)
*   lineno:发生错误的行号(数字)
*   colno:发生错误的列号(数字)
*   error:Error对象

若该函数返回true,则阻止执行默认事件处理函数,如异常信息不会在console中打印。没有返回值或者返回值为false的时候,异常信息会在console中打印

addEventListener('error')

监听js运行时错误事件,会比window.onerror先触发,与onerror的功能大体类似,不过事件回调函数传参只有一个保存所有错误信息的参数,不能阻止默认事件处理函数的执行,但可以全局捕获资源加载异常的错误

window.addEventListener('error', function(event) { ... })

当资源(如img或script)加载失败,加载资源的元素会触发一个Event接口的error事件,并执行该元素上的onerror()处理函数。这些error事件不会向上冒泡到window,但可以在捕获阶段被捕获
因此如果要全局监听资源加载错误,需要在捕获阶段捕获事件
//图片加载失败使用默认图片,依旧加载失败超过三次使用base64图片
window.addEventListener('error',function(e){
    let target = e.target, // 当前dom节点
        tagName = target.tagName,
        count = Number(target.dataset.count ) || 0, // 以失败的次数,默认为0
        max= 3; // 总失败次数,此时设定为3
    // 当前异常是由图片加载异常引起的
    if( tagName.toUpperCase() === 'IMG' ){
        if(count >= max){
            target.src = '';
        }else{
            target.dataset.count = count + 1;
            target.src = '//xxx/default.jpg';
        }
    }
},true)
### 解决 Vue 项目中的网络错误 在网络请求过程中遇到错误是前端开发常见的挑战之一。对于 Vue.js 应用程序而言,处理这些异常情况至关重要。 #### 处理 HTTP 请求失败的情况 当涉及到像 `axios` 这样的库来发起 AJAX 调用时,在捕获到服务器端返回的状态码不是成功的状态(即不在2xx范围内),可以定义全局拦截器来进行统一管理[^1]: ```javascript import axios from 'axios'; const instance = axios.create({ baseURL: process.env.VUE_APP_API_URL, }); // Add a request interceptor instance.interceptors.request.use( config => { const token = localStorage.getItem('token'); if (token) { config.headers['Authorization'] = `Bearer ${token}`; } return config; }, error => Promise.reject(error) ); // Add a response interceptor instance.interceptors.response.use( response => response.data, async error => { const originalRequest = error.config; // If the error is due to an expired JWT or unauthorized access... if ( error.response && (error.response.status === 401 || error.response.status === 403) && !originalRequest._retry ) { originalRequest._retry = true; try { await refreshAccessToken(); return instance(originalRequest); } catch (_error) { logoutUser(); // Redirect user to login page. throw _error; } } return Promise.reject(error); } ); export default instance; ``` 这段代码展示了如何设置 Axios 的实例,并为其配置了一个响应拦截器用于检测特定类型的HTTP错误(如未授权访问)。如果发现令牌过期,则尝试刷新它再重试原始请求;否则就抛出拒绝承诺让调用者知道发生了什么问题。 #### 对付连接级别的故障 除了上述提到的服务端逻辑外,客户端也可能遭遇诸如断网之类的物理层面上的问题。为了应对这种情况,可以在应用程序启动之初监听在线/离线事件并作出相应反应: ```javascript window.addEventListener('online', () => console.log('Back online!')); window.addEventListener('offline', () => alert('You seem to be offline.')); ``` 另外还可以考虑集成第三方 SDK 或框架提供的功能,比如 PWA 支持下的 Service Worker 技术能够帮助实现更复杂的离线体验优化方案[^2]。 #### 配置无线适配器选项调整 尽管这通常属于操作系统层面而非纯粹的编程范畴内的话题,但如果确实是因为 Wi-Fi 设置不当引起频繁掉线的话,适当调节一些参数也许会有意想不到的效果。不过需要注意的是,实际效果因设备而异,并不一定适用于所有人[^3]。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值