1

我正在为 Edge 构建一个扩展,但在调试我的 background.js 时遇到了问题。我根本无法将它打印到控制台。我可以通过 content.js 很好地打印到控制台。以下是我尝试过的一些 console.log 语句:

background.js

console.log("PLEASE PRINT");

browser.browserAction.onClicked.addListener(function(tab) {
    console.log("CLICKED BUTTON");
    browser.tabs.executeScript(null,{code:"window.print()"});
});

browser.tabs.onActivated.addListener(activeInfo => {
    console.log("onActivated listener");
});

browser.tabs.onActivated.addListener(function(activeInfo) {
    console.log("onActivated listener");
});

function printALog() {
    console.log("i pray");
}

function handleActivated(activeInfo) {
  console.log("PLEASE");
}


browser.tabs.onActivated.addListener(handleActivated);
browser.windows.onFocusedChanged.adddListener(handleActivated);
browser.webNavigation.onCompelted.addListener(handleActivated);

我做错了什么还是使用 Edge 的开发人员工具无法做到这一点?

4

1 回答 1

0

运行 background.js 的扩展页面基本上是一个特殊的独立页面。它不与其他网页选项卡共享 windows 对象和控制台输出。

在 Edge 中,可以通过扩展管理菜单查看后台页面(正如灰原爱所说,这是链接)。您将在那里看到您的控制台输出。

但请注意,如果您使用 manifest.json 属性将任何扩展脚本注入到页面上下文中content_scripts(如果您计划与页面内容交互,您会希望这样做),它们实际上会使用该页面上下文进行控制台输出。有时它很有用,但有时您希望将所有日志放在一个地方。在这种情况下,您可以使用这些消息将调试消息发送到后台控制台,browser.runtime.sendMessage并将这些消息中继到后台页面中的控制台。

于 2017-03-06T08:37:46.473 回答