PageMod的Firefox插件附加事件没有发出事件

Firefox Addon Attach event for PageMod is not emitting events

本文关键字:出事件 事件 Firefox 插件 PageMod      更新时间:2023-09-26

我无法在我的插件和我的附加脚本之间进行通信。PageMod的attach事件可以工作,但是它不会向list-getter发送getElements事件。如何正确使用port.emit法?谢谢!

index.js(插件)

var pageMod = require('sdk/page-mod');
var data = require("sdk/self").data;
pageMod.PageMod({
  include: "*.workflowy.com",
  contentScriptFile: [data.url("jquery-1.11.3.min.js"), data.url("list-getter.js")], 
  onAttach: function(worker) {
    // For some reasong the worker doesn't emit?
    worker.port.emit("getElements");
    worker.port.on("gotElements", function(times) {
      function printValues(el) {
        console.log(el);
      }
      times.forEach(printValues);
    });
  }
});

list-getter.js (contentScriptFile)

self.port.on("getElements", function() {
  var timeRegex = /'bam|pm/g
  var openLists = $('.project.open').find('.content');
  var times = []
  for (var i = 0; i < openLists.length; i++) {
    if (openLists[i].innerHTML.match(timeRegex)) {
      times.push(openLists[i].innerHTML)
    }
  }
  self.port.emit("gotElements", times);
});

我犯了一个不可思议的错误。确保将您想要由数据对象加载的任何内容放在data文件夹中。我有两份,改错了一份。谢谢。

index.js

var pageMod = require('sdk/page-mod');
var data = require("sdk/self").data;
pageMod.PageMod({
  include: "*.workflowy.com",
  contentScriptFile: data.url("list-getter.js"), 
  onAttach: function(worker) {
    worker.port.emit("getElements");
    worker.port.on("gotElement", function(times) {
      function printValues(el) {
        console.log(el);
      }
      times.forEach(printValues);
    });
  }
});

list-getter.js

self.port.on("getElements", function(openProject) {
  var times = []
  var timeRegex = /'b([1-9]pm|[1-9]am|1[0-2]am|1[0-2]pm)/g;
  var openLists = document.querySelectorAll('.content');
  for (var i = 0; i < openLists.length; i++) {
    if (openLists[i].innerHTML != "") {
      if (openLists[i].innerHTML.match(timeRegex)) {
        times.push(openLists[i].innerHTML);
      }
    }
  }
  self.port.emit("gotElement", times);
)};