我使用它的附加构建器 SDK 为 Firefox 制作了附加组件。起初它工作得很好,但是当我切换标签时它开始表现得很奇怪并且失去了它的功能。我知道我一定遗漏了一些东西,它可能与脚本之间的通信有关,但我不知道是什么。
我没有发布代码,而是公开了扩展,这里是链接。
如果你仍然需要我发布代码,女巫你不应该,只要问我,我会做的。 告诉我我应该怎么做才能使我的扩展在许多选项卡上分别工作,但同时工作。
我使用它的附加构建器 SDK 为 Firefox 制作了附加组件。起初它工作得很好,但是当我切换标签时它开始表现得很奇怪并且失去了它的功能。我知道我一定遗漏了一些东西,它可能与脚本之间的通信有关,但我不知道是什么。
我没有发布代码,而是公开了扩展,这里是链接。
如果你仍然需要我发布代码,女巫你不应该,只要问我,我会做的。 告诉我我应该怎么做才能使我的扩展在许多选项卡上分别工作,但同时工作。
在我看来,第 59-64 行实际上应该在 attachTabWorker 函数中。您只需要将面板的工作人员保存到当前工作人员通信。
我会像这样连接你的端口通信:
function attachTabWorker(tab) {
// Attach and store
var tabWorker = tabWorkers[tab.id] = tab.attach({
contentScriptFile: [data.url("clear.js"),data.url("jquery.js")]
});
// Clean up
tabWorker.on("detach", function() {
if (getTabWorker(tab) === tabWorker) {
delete tabWorkers[tab.id];
}
});
tabWorker.port.on('hiderOn',function(tag){
panel1.port.emit('hiderOn', tag);
});
tabWorker.port.on('hiderOff',function(tag){
panel1.port.emit('hiderOff', tag);
});
}
否则,您只会在第一次运行时为 activeTab 设置端口通信链接,而不是像我认为您想要的那样为每个选项卡设置端口通信链接。代码 getActiveTabWorker().port.on
... 在加载项启动时运行一次,它只为 activeTab 而不是所有选项卡创建一个侦听器。我希望这是有道理的。