firefox addon:quit-application observer无法正常工作

时间:2015-04-06 07:44:45

标签: javascript firefox firefox-addon

我一直在尝试使用观察者一段时间,但似乎我无法让他们工作。我将observe函数放在我的扩展的不同模块中,以及我的代码的不同部分。从任何地方注册它,但似乎我试过的每一种方式都是一种消极的方式。我无法让它发挥作用。我的目标是在用户退出Firefox时进行监听,以便清除插件的首选项对象。截至目前,我的观察者在bootstrap.js中,这就是我实现它的方式。我以这种方式实现了我的observe函数,因为在this stackoverflow帖子中提到这是观察退出应用程序通知的正确方法。从旁注来看,注册的观察者在控制台日志中打印,但“哦观察”没有。

function myObserver()
{
  this.register();
}
myObserver.prototype = {
  observe: function(subject, topic, data) {
    console.log("oh observing!!");

  if (topic == "app-startup" || topic == "profile-after-change") {
     var observerService = Components.classes["@mozilla.org/observer-service;1"]
                                     .getService(Components.interfaces.nsIObserverService);
     observerService.addObserver(this, "quit-application", false);
   }

    else if (topic == "quit-application-requested" || topic == "quit-application")
    {
    console.log("browser closing");
    alert('hello');
    myextension.Utils.prefService.clearUserPref("questionType");
    myextension.Utils.prefService.clearUserPref("clickThrough");
    this.unregister();
    }
  },

  register: function() {

            var observerService = Components.classes["@mozilla.org/observer-service;1"]
                .getService(Components.interfaces.nsIObserverService);

            observerService.addObserver(this, "quit-application-requested",false);
            observerService.addObserver(this, "quit-application",false);
            observerService.addObserver(this, "app-startup", false);
            observerService.addObserver(this, "profile-after-change", false);
            console.log("observers registered");

  },

     unregister: function() {
        var observerService = Components.classes["@mozilla.org/observer-service;1"]
            .getService(Components.interfaces.nsIObserverService);
        observerService.removeObserver(this, "quit-application-requested");
        console.log("unregistering obs");
    }
}

这是我的启动功能:

    function startup(data, reason) {
      Components.utils.import("chrome://ext/content/commons.jsm");
      let wm = Cc["@mozilla.org/appshell/window-mediator;1"].
               getService(Ci.nsIWindowMediator);

      let windows = wm.getEnumerator("navigator:browser");
      while (windows.hasMoreElements()) {
        let domWindow = windows.getNext().QueryInterface(Ci.nsIDOMWindow);

        WindowListener.setupBrowserUI(domWindow);

      }

  // Wait for any new browser windows to open
  wm.addListener(WindowListener);

}

这是我的setupBrowserUI函数,我在其中注册观察者:

  setupBrowserUI: function(domWindow) {
    extension.onLoad(domWindow.gBrowser);
    observer = new myObserver();
  }

1 个答案:

答案 0 :(得分:2)

简单方法:

https://developer.mozilla.org/en-US/docs/Mozilla/JavaScript_code_modules/Services.jsm

let observer = {
  observe: function() {
         dump("oh observing")
  }
};

function startup(data, reason)
{
  Services.obs.addObserver(observer, "*", false);
  observer.observe();
}

我的建议是创建一个包含首选项的日志文件;要将转储调用输出到文件,请将 browser.dom.window.dump.file 设置为应创建日志的文件目标,然后重新启动应用程序。

https://developer.mozilla.org/en-US/docs/Mozilla/Preferences/Preference_reference/browser.dom.window.dump.file