打开新窗口时 debugger 拦截,以查看调用栈排查问题

在日常 bug 修复中,免不了遇到一些打开新窗口后参数不对,或是想要添加新参数的情况。这时候我们可以通过拦截打开新窗口的行为,以便查看调用栈,排查问题或者找到对应的代码位置以添加代码。

下面是我记录的一些自己有用到的一些方法,帮助我在开发中更快的定位代码🚀

情况1: 使用 window.open 打开新窗口

触发跳转代码

javascript 复制代码
window.open('https://example.com', '_blank');

拦截方式

可以通过重写 window.open 方法,以便捕获所有通过 window.open 打开的行为:

javascript 复制代码
const originalWindowOpen = window.open;

window.open = function(url, target, features) {
  debugger; // 捕获所有通过 window.open 打开的行为
  console.info('window.open 打开:', url, target, features);
  return originalWindowOpen.call(window, url, target, features);
};

情况2: 使用a标签进行的跳转

触发跳转代码

javascript 复制代码
let a = document.createElement('a')
a.setAttribute('href', `${url}/${params}`)
a.setAttribute('target', '_blank')
a.click()
a.remove()

拦截方式

javascript 复制代码
const originalAnchorClick = HTMLAnchorElement.prototype.click;

HTMLAnchorElement.prototype.click = function() {
  debugger; // 捕获所有通过 a.click() 打开的行为
  console.info('a标签打开:', this.href, this.target);
  return originalAnchorClick.call(this);
};

总方法

javascript 复制代码
const DebuggerTool = {
  originalWindowOpen: window.open,
  originalAnchorClick: HTMLAnchorElement.prototype.click,

  init: function () {
    this.interceptWindowOpen();
    this.interceptAnchorClick();
  },

  interceptWindowOpen: function () {
    window.open = function (url, target, features) {
      debugger;
      console.info("window.open 打开:", url, target, features);
      return DebuggerTool.originalWindowOpen.call(
        window,
        url,
        target,
        features
      );
    };
  },

  interceptAnchorClick: function () {
    HTMLAnchorElement.prototype.click = function () {
      debugger;
      console.info("a标签打开:", this.href, this.target);
      return DebuggerTool.originalAnchorClick.call(this);
    };
  },
};

DebuggerTool.init();
相关推荐
可子是我的小猫2 分钟前
【JS】模块(一)
javascript
跟橙姐学代码10 分钟前
Python 类的正确打开方式:从新手到进阶的第一步
前端·python·ipython
Jagger_10 分钟前
SonarQube:提升代码质量的前后端解决方案
前端·后端·ai编程
Becauseofyou13713 分钟前
如果你刚入门Three.js,这几个开源项目值得你去学习
前端·three.js
菜市口的跳脚长颌14 分钟前
前端大文件上传全攻略(秒传、分片上传、断点续传、并发控制、进度展示)
前端
不一样的少年_16 分钟前
同事以为要重写,我8行代码让 Vue 2 公共组件跑进 Vue 3
前端·javascript·vue.js
草履虫建模20 分钟前
在 RuoYi 中接入 3D「园区驾驶舱」:Vue2 + Three.js + Nginx
运维·开发语言·javascript·spring boot·nginx·spring cloud·微服务
云枫晖23 分钟前
JS核心知识-数据转换
前端·javascript
xuyanzhuqing24 分钟前
代码共享方案-多仓库合并单仓库
前端
RaidenLiu25 分钟前
Riverpod 3:重建控制的实践与性能优化指南
前端·flutter