firefox 插件:退出应用程序观察器不工作

firefox addon: quit-application observer not working

我已经尝试使用观察者一段时间了,但似乎无法让它们发挥作用。我将 observe 函数放在扩展的不同模块以及代码的不同部分。从任何地方注册它,但似乎我尝试过的每一种方式都只是一种麻木。我无法让它工作。我的目标是监听用户何时退出 Firefox,这样我就可以清除我的插件的首选项对象。截至目前,我的观察者在 bootstrap.js,这就是我实现它的方式。我以这种方式实现了我的观察功能,因为在 this Whosebug post 中提到这是观察退出应用程序通知的正确方法。在旁注中,已注册的观察员会打印在控制台日志中,但 "oh observing" 不会。

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();
  }

简单的方法:

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