前端监听页面中的某些异常情况

其实工作一定时间之后,对页面中某些异常情况的处理也要考虑到位了!

这个也是进阶高级前端的一个步骤之一吧

面试中也会问 你如何监听页面中出现undefined或者null的情况 并对服务器端上报

如果要补获undefined其实也简单 就可以用到 document.body然后获取之前的dom元素的字符串 然后判断字符串中是否包含undefined

javascript 复制代码
const errorMap = new Map()

const errorArray = JSON.stringify(document.body.innerHTML).match(/undefined|NaN|null/g)
      if (JSON.stringify(document.body.innerHTML).match(/undefined|NaN|null/) !== null) {
        errorArray.forEach(item => {
          !errorMap.get(item) ? errorMap.set(item, 1) :  errorMap.set(item, errorMap.get(item) + 1)
        })
        for(let [key,value] of errorMap.entries()) {
          console.warn(`请注意页面中${key}出现了:${value}次`)
        }
        logService(errorMap) // 服务端上报
      } else {
        console.log("页面正常")
      }

最近也是越来越感觉到。随着工作时间的增长但是吧 瓶颈其实也越来越明显。这样的话 其实也挺危险的。总是要保持长久学习的习惯 才不至于被淘汰吧。毕竟太卷了 现在

最近公司招人,看到那么多优秀的人 依然在找工作,哎 一言难尽

加油吧

相关推荐
anOnion28 分钟前
构建无障碍组件之Carousel Pattern
前端·html·交互设计
ssshooter37 分钟前
Tauri 2 iOS 开发避坑指南:文件保存、Dialog 和 Documents 目录的那些坑
前端·后端·ios
Можно1 小时前
深入理解 ES6 Proxy:与 Object.defineProperty 的全面对比
前端·javascript·vue.js
Birdy_x2 小时前
接口自动化项目实战(1):requests请求封装
开发语言·前端·python
天天向上10243 小时前
vue el-table实现拖拽排序
前端·javascript·vue.js
柳杉4 小时前
Three.js × Blender:从建模到 Web 3D 的完整工作流深度解析
前端·javascript·数据可视化
reembarkation5 小时前
vue3中使用howler播放音频列表
前端·vue.js·音视频
手握风云-5 小时前
基于 Java 的网页聊天室(三)
服务器·前端·数据库
weixin199701080165 小时前
《识货商品详情页前端性能优化实战》
前端·性能优化
Forever7_5 小时前
重磅!Vue3 手势工具正式发布!免费使用!
前端·前端框架·前端工程化