1

我正在做一些非常简单的事情......我无法弄清楚。我创建了一个扩展,它所做的只是获取一个变量。我希望能够从我的网页访问该变量。有什么想法吗?

我为什么要这样做的一点背景。我需要有 chrome 访问权限才能获得这个变量,这就是我首先制作这个扩展的原因。

4

1 回答 1

0

您可能想查看此链接:Interaction between privileged and non-privileged pages for some code-samples on send data from chrome (priveleged) to unprivileged document (webpage).

在扩展中:

var myExtension =
{
  myListener: function(evt)
  {
    alert("Received from web page: " + 
           evt.target.getAttribute("attribute1") + "/" +
           evt.target.getAttribute("attribute2"));

/* the extension answers the page*/
    evt.target.setAttribute("attribute3", "The extension");

    var doc = evt.target.ownerDocument;

    var AnswerEvt = doc.createElement("MyExtensionAnswer");
    AnswerEvt.setAttribute("Part1", "answers this.");

    doc.documentElement.appendChild(AnswerEvt);

    var event = doc.createEvent("HTMLEvents");
    event.initEvent("MyAnswerEvent", true, false);
    AnswerEvt.dispatchEvent(event);
  }
}

document.addEventListener("MyExtensionEvent", function(e) { myExtension.myListener(e); }, false, true);
// The last value is a Mozilla-specific value to indicate untrusted content is allowed to trigger the event.

在网页中:

document.addEventListener("MyAnswerEvent",function(e) { ExtensionAnswer(e); },false);

var element;

function CallExtension()
{
  var element = document.createElement("MyExtensionDataElement");
  element.setAttribute("attribute1", "foobar");
  element.setAttribute("attribute2", "hello world");
  document.documentElement.appendChild(element);
  var evt = document.createEvent("Events");
  evt.initEvent("MyExtensionEvent", true, false);
  element.dispatchEvent(evt);
}

function ExtensionAnswer(EvtAnswer)
{
  alert(element.getAttribute("attribute3") + " " +
        EvtAnswer.target.getAttribute("Part1"));
}

希望这可以帮助。

于 2013-03-28T14:07:20.710 回答