document.activeElement返回一个XULElement

时间:2013-10-23 17:24:14

标签: javascript firefox-addon xul firefox-addon-sdk

当用户在我的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]

1 个答案:

答案 0 :(得分:2)

getMostRecentBrowserWindow会返回ChromeWindow对象。所以activeElement`是一个XUL元素是正常的。

你应该做的是

window: require("sdk/window/utils").getMostRecentBrowserWindow().gBrowser.contentWindow