打开新窗口时 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();
相关推荐
开心工作室_kaic5 分钟前
基于Java的可携宠物酒店管理系统的设计与实现(论文+源码)_kaic
java·开发语言·javascript·数据库·微信小程序·小程序·宠物
serve the people8 分钟前
vue中父组件给子组件传递数据
前端·javascript·vue.js
噫吁嚱!!!17 分钟前
若依前端后打成一个JAR包部署
java·前端·jar
乔没乔见Joe20 分钟前
使用Apifox创建接口文档,部署第一个简单的基于Vue+Axios的前端项目
前端·javascript·vue.js·vscode·axios
szqcloud1 小时前
腾讯云SDK 选择指引
前端·云计算·音视频·腾讯云
m0_528723811 小时前
在前端开发中,如何处理列表分页时遇到接口延迟或数据返回顺序不一致的问题
前端·javascript·vue.js
爱喝醋的雷达1 小时前
Java项目-----图形验证码登陆实现
java·开发语言·前端
你会发光哎u1 小时前
彻底理解TypeScript函数语法
开发语言·前端·typescript
cuiZero01 小时前
基础【前端】面试题
前端
speedoooo1 小时前
用AI构建小程序需要多久?效果如何?
前端·人工智能·小程序·前端框架