小编Orr*_*rry的帖子

chrome.runtime.onConnect.addListener()在初始chrome标签上不起作用

更新
现在看来,这只是在我描述的第一种情况下发生,即重新加载了“扩展”选项卡并打开了一个新选项卡。可能的错误?


我正在使用background.js页面和content-script.js设置chrome扩展。

两者通过端口相互通信。现在的工作方式是,每次激活或更新选项卡时,端口就会在后台初始化,并且内容脚本通过chrome.runtime.onConnect.addListener()(返回端口)侦听它。

这很好。两种(类似)情况除外:

  1. 在工具>扩展页面中重新加载扩展并创建新选项卡后。
  2. Chrome关闭并重新启动后,在新标签页上。

我有一些日志显示在这些情况下,background.js 确实初始化了端口...但是内容脚本由于某种原因未收到它。

这些是我正在做的基础:

background.js

// When a tab gets activated
chrome.tabs.onActivated.addListener(function(tab) {
    port = chrome.tabs.connect(tab.tabId, { name: "fh-ext-messenger" });
    console.log(port)
    initPortListener(port);
});

// When a tab is updated
chrome.tabs.onUpdated.addListener(function(tab) {
    port = chrome.tabs.connect(tab, { name: "fh-ext-messenger" });
    console.log(port)
    initPortListener(port);
});
Run Code Online (Sandbox Code Playgroud)

content.js

chrome.runtime.onConnect.addListener(function(port) {
    console.log(port);
    // ...
}
Run Code Online (Sandbox Code Playgroud)

关于为什么在初始选项卡上不起作用的任何想法?

javascript google-chrome google-chrome-extension

5
推荐指数
1
解决办法
2292
查看次数

onActivated和onHighlighted之间的区别?

我无法理解两者之间的区别.

onActivated: 当窗口中的活动选项卡发生更改时触发. http://developer.chrome.com/extensions/tabs.html#event-onActivated

onHighlighted: 当窗口中突出显示或选定的选项卡发生变化时触发. http://developer.chrome.com/extensions/tabs.html#event-onHighlighted

javascript google-chrome google-chrome-extension

4
推荐指数
1
解决办法
372
查看次数