首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >通过postMessage()进行通信

通过postMessage()进行通信
EN

Stack Overflow用户
提问于 2012-08-08 00:22:20
回答 1查看 2.1K关注 0票数 1

我正在开发一个Firefox扩展,我需要能够在插件脚本和内容脚本之间进行通信。我有一个工作方向:将脚本的URL从插件脚本传递到内容脚本。然而,我也需要能够在相反的方向上。我的main.js文件如下所示:

代码语言:javascript
复制
var data = require("self").data;
var pageMod = require("page-mod");
pageMod.PageMod({
  include: "https://trello.com/board/*",
  contentScriptWhen: 'end',
  contentScriptFile: data.url("scrumello_beta.user.js"),
  onAttach: function(worker) {
    worker.postMessage(data.url("scrumello_beta.js"));
    worker.on("message", function(addonMessage)
    {
        console.log(addonMessage);
    });
  }
});

在客户端脚本中,我有以下方法:

代码语言:javascript
复制
    function OpenProcess(SCRNumber)
    {
        self.postMessage(SCRNumber); 
    }

但是,当调用此方法时,我得到以下错误:

代码语言:javascript
复制
Timestamp: 8/7/2012 12:15:58 PM
Error: NS_ERROR_XPC_NOT_ENOUGH_ARGS: Not enough arguments [nsIDOMWindow.postMessage]
Source File: resource://jid0-3mulsijczmtjeuwkd5npayasqf8-at-jetpack/scogan-3/data/scrumello_beta.js
Line: 1038

这将阻止worker.on("message"...事件不会被触发。据我所知,postMessage只接受一个参数,所以这里的任何帮助都将不胜感激。

编辑:我已将postMessage调用更改为

代码语言:javascript
复制
self.postMessage(SCRNumber, "*"); 

我将其封装在console.log中,这两个文件都在打印中,所以我必须假设消息实际上是发布的。但是,main.js中的事件处理程序永远不会提取消息,因为我在其中的console.log从未打印过。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-08-08 02:12:17

这就是我是如何做到的。(请注意,我从未使用过self.postmessage)

内容脚本通信的附加脚本(main.js):

代码语言:javascript
复制
contentPage = pageMod.PageMod({
  onAttach: function(worker) {

    // Post a message directly to the content script
    worker.postMessage("any thing you want to respond");

    // Depending on the message, respond with different data
    worker.port.on('getFact', function() {
      worker.postMessage("any thing you want to respond");
    });
    worker.port.on('getEnabled', function() {
      worker.postMessage("any thing you want to respond");
    });
  }
});

--

下面是响应附加脚本的内容脚本:

代码语言:javascript
复制
// Get data from the addon script
self.on('message', function(msg) {
  // Do something depending on the message passed
});

--

最后,内容脚本可以像这样与附加组件脚本通信:

代码语言:javascript
复制
self.port.emit("message to send to add-on script")

上面的代码将触发main.js中的worker.port.on代码。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/11850154

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档