当用户在我的Firefox插件上按CTRL + SPACE时,我正在尝试获取焦点元素。
为此,我想使用 document.activeElement 来获取焦点元素,但它不起作用。它总是返回一个XULElement。
我在这个附加组件中只有两个文件:
LIB / main.js
var self = require ("sdk/self");
var workers = require("sdk/content/worker");
let worker = workers.Worker({
window: require("sdk/window/utils").getMostRecentBrowserWindow(),
contentScriptFile: self.data.url("script.js")
});
var { Hotkey } = require("sdk/hotkeys");
var showHotKey = Hotkey({
combo: "control-space",
onPress: function() {
worker.port.emit ("getFocused", "");
}
});
和文件Data / script.js
self.port.on ('getFocused', function (msg){
var campo = document.activeElement;
alert (campo);
});
(如何在此处看到:Add-on SDK Builder Test Project)
那么,有人可以帮助我吗?
可以从XULElement获取输入文本或textarea并更改其文本吗?
非常感谢!
------------------------编辑----------------------
我不知道它是否有帮助,但是,当网址文本区域(我们编写网站的地址)具有焦点时,它会返回
[object HTMLInputElement]
答案 0 :(得分:2)
getMostRecentBrowserWindow
会返回ChromeWindow对象。所以activeElement`是一个XUL元素是正常的。
你应该做的是
window: require("sdk/window/utils").getMostRecentBrowserWindow().gBrowser.contentWindow