4

内容脚本.js

chrome.runtime.onMessage.addListener(
  function(request, sender, sendResponse) {
    console.log(sender.tab ?
                "from a content script:" + sender.tab.url :
                "from the extension");
    if (request.greeting == "hello")
      sendResponse({farewell: "goodbye"});
  });

背景.js

chrome.browserAction.onClicked.addListener(function(tab) {
    chrome.tabs.query({active: true, currentWindow: true}, function(tabs) {
        chrome.tabs.sendMessage(tabs[0].id, {greeting: "hello"}, function(response) {
            console.log(response.farewell);
        });
    });
});

这有时有效,有时无效。

无效的情况:

1)当我重新加载扩展并单击现有选项卡上的扩展图标时 2)当我在 background.js 中添加断点时

有效的案例:

1)当我重新加载扩展并重新加载/加载新选项卡并且在 background.js 中没有添加断点时

抛出的错误通常是:

Port: Could not establish connection. Receiving end does not exist. lastError:29
Error in event handler for 'undefined': Cannot read property 'farewell' of undefined TypeError: Cannot read property 'farewell' of undefined
at chrome-extension://glbcapgiojbbnjhngjdmoglaamjbjjak/background.js:16:28
at <error: illegal access>
at Event.dispatchToListener (event_bindings:356:21)
at Event.dispatch_ (event_bindings:342:27)
at Event.dispatch (event_bindings:362:17)
at Object.chromeHidden.Port.dispatchOnDisconnect (miscellaneous_bindings:258:27) 

任何人都可以对此有所了解吗?我觉得特别奇怪的是断点会导致它失败(几乎就像暂停 background.js 会导致事件监听器死掉一样)

4

2 回答 2

1

我猜..由于断点,焦点移动到后台脚本。您将 chrome.tabs.query 函数与 {active: true, currentWindow: true} 一起使用,但后台脚本没有 tabid。如果你想使用断点调试,你应该在回调函数内部做一个点。

于 2015-03-30T07:22:13.607 回答
1

事实证明,当在 background.js 中设置断点时,tabs 对象变为:

0: Object
active: true
favIconUrl: ""
highlighted: true
id: 20
incognito: false
index: 0
pinned: false
selected: true
status: "complete"
title: "Developer Tools - chrome-extension://glbcapgiojbbnjhngjdmoglaamjbjjak/_generated_background_page.html"
url: "chrome-devtools://devtools/devtools.html dockSide=right&toolbarColor=rgba(223,223,223,1)&textColor=rgba(0,0,0,1)"
windowId: 19

事件侦听器位于不同的选项卡中,因此“接收端不存在”。话虽如此,我需要找到一种将消息发送到正确选项卡的方法(我还使用 oauth2 进行了一些重定向,因此它也会混淆选项卡选择)。

于 2013-08-18T16:05:15.250 回答