我有一个可在Chrome上运行的扩展程序,用于监控活动标签页以进行网址更改。
具体来说,我需要检测URL何时更改,但没有新页面加载或导航。有些网站会这样做(例如,当您点击在YouTube上观看另一个视频时)。
在Chrome上,我完成了以下操作:
chrome.tabs.onUpdated.addListener(function(tabId, changeInfo, tab) {
if (changeInfo && changeInfo.status == "complete") {
//do stuff here
}
});
如何在Firefox插件中检测到此类更改?
我被告知要使用:Listening to events on all tabs,但我无法将它放在一起。其中一个问题是扩展中未定义gBrowser
。
我做错了什么?
有更简单的方法吗?
答案 0 :(得分:4)
使用ProgressListener通知位置更改。
要安装侦听器,请使用viewFor将SDK选项卡转换为其原始(旧)表示。 使用modelFor和getTabForContentWindow可以进行向后转换。
const tabs = require("sdk/tabs");
const {viewFor} = require('sdk/view/core');
const {modelFor} = require('sdk/model/core');
const {getBrowserForTab, getTabForContentWindow} = require("sdk/tabs/utils");
const {Ci, Cu} = require("chrome");
Cu.import("resource://gre/modules/XPCOMUtils.jsm", this);
var progressListener = {
QueryInterface: XPCOMUtils.generateQI([Ci.nsIWebProgressListener, Ci.nsISupportsWeakReference]),
onLocationChange: function(aProgress, aRequest, aURI) {
var highLevel= modelFor(getTabForContentWindow(aProgress.DOMWindow));
console.log("onLocationChange ", highLevel.url);
}
};
tabs.on('open', function(newTab) {
var lowLevel = viewFor(newTab);
var browser = getBrowserForTab(lowLevel);
browser.addProgressListener(progressListener);
});
不要忘记在扩展卸载时删除侦听器。选项卡侦听器会自动删除,但ProgressListeners不会。
答案 1 :(得分:0)
如果您使用附加SDK,则需要查看错误的文档。以下是tab docs。
如上所述,您可以创建一个类似的监听器:
var tabs = require("sdk/tabs");
// Listen for tab openings.
tabs.on('open', function onOpen(tab) {
myOpenTabs.push(tab);
});
// Listen for tab content loads.
tabs.on('ready', function(tab) {
console.log('tab is loaded', tab.title, tab.url);
});
您查看的所有文档都应该是 developer.mozilla.org/en-US/Add-ons/SDK 的子集。
答案 2 :(得分:0)
我发现两者之间的activate
和pageshow
事件涵盖了我在转换标签之间可以想到的所有URL更改,在新标签页中打开页面,关闭标签,刷新页面,然后输入新的URL。
var updateURL = function (tab) {
var oldURL = url;
var url = tab.url;
console.log(url);
};
tabs.on("activate", updateURL);
tabs.on("pageshow", updateURL);