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

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

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

面试中也会问 你如何监听页面中出现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("页面正常")
      }

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

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

加油吧

相关推荐
新中地GIS开发老师33 分钟前
Cesium 军事标绘入门:用 Cesium-Plot-JS 快速实现标绘功能
前端·javascript·arcgis·cesium·gis开发·地理信息科学
Superxpang40 分钟前
前端性能优化
前端·javascript·vue.js·性能优化
Rysxt_1 小时前
Element Plus 入门教程:从零开始构建 Vue 3 界面
前端·javascript·vue.js
隐含1 小时前
对于el-table中自定义表头中添加el-popover会弹出两个的解决方案,分别针对固定列和非固定列来隐藏最后一个浮框。
前端·javascript·vue.js
大鱼前端1 小时前
Turbopack vs Webpack vs Vite:前端构建工具三分天下,谁将胜出?
前端·webpack·turbopack
你的人类朋友1 小时前
先用js快速开发,后续引入ts是否是一个好的实践?
前端·javascript·后端
知识分享小能手1 小时前
微信小程序入门学习教程,从入门到精通,微信小程序核心 API 详解与案例(13)
前端·javascript·学习·react.js·微信小程序·小程序·vue
子兮曰2 小时前
npm workspace 深度解析:与 pnpm workspace 和 Lerna 的全面对比
前端·javascript·npm
颜酱2 小时前
用搬家公司的例子来入门webpack
前端·javascript·webpack