Firefox附加组件 - 如何在main.js中创建A元素?

时间:2013-01-30 19:21:02

标签: firefox-addon firefox-addon-sdk

要从所有标签的网址中提取域名,我们需要在附加组件的main.js文件中创建A元素:

function listTabs() {
var tabs = require("sdk/tabs");
for each (var tab in tabs)
{
var tab_url = document.createElement('a');
tab_url.href = tab.url;
var domain[] = tab_url.hostname;
}

但是我们收到错误“文档未定义”。我们也尝试过content.document,但这也行不通。

(我知道有其他方法可以提取域名,但出于兼容性原因,这是我们的附加组件应该这样做的唯一方法。)

希望有人可以提供帮助。

干杯

1 个答案:

答案 0 :(得分:4)

我真的不明白你要做什么,所以这里有两种不同的方法。

如果您需要访问网页的文档元素,则必须使用更低级别的方法,除非您想要简化并只使用page-mod

以下是在标签页面上创建A元素的方法:

var { getTabs, getTabContentWindow } = require('sdk/tabs/utils');

function listTabs1() {
  var tabs = getTabs();
  tabs.forEach(function (tab) {
    // Fake a newly created document
    var window = getTabContentWindow(tab);    
    var document = window.document;
    var tab_url = document.createElement('a');
    tab_url.setAttribute("href", tab.url);
  });
}

我建议使用page-mod来修改此页面而不是上面的代码。

但是如果你只是想检查每个标签的主机,你可以像你一样循环遍历它们,然后使用URL模块进行困难的主机名解析。

var URL = require('sdk/url').URL;
var tabs = require("sdk/tabs");

function listTabs2() {
  tabs.forEach(function (tab) {
      var url = URL(tab.url);
      console.log(url.hostname);
  });

}

最后一个提示是,您可以轻松编写一个使用nsIEffectiveTLDService的模块来查找您认为自己拥有的主机名的顶级域,因为所有解析URL都容易出错。 https://developer.mozilla.org/en-US/docs/XPCOM_Interface_Reference/nsIEffectiveTLDService

祝你好运!