Изменить синтаксис прослушивателя событий в Javascript - PullRequest
3 голосов
/ 05 июля 2011

Я написал некоторый код в Javascript, который нуждается в некотором преобразовании, но я не знаю, как этого добиться.

мой код:

gBrowser.addEventListener("DOMContentLoaded", function(e) {...}), false);

в

window.addEventListener("load", function() {myExtension.init()}, false);

Ключом здесь является передача аргумента e.Я пробовал "function (e)" и "myExtension.init (e)", но это не работает.

EDIT (весь мой код - код функции находится в конце кода):

var myExt_urlBarListener = {
  QueryInterface: function(aIID)
  {
   if (aIID.equals(Components.interfaces.nsIWebProgressListener) ||
       aIID.equals(Components.interfaces.nsISupportsWeakReference) ||
       aIID.equals(Components.interfaces.nsISupports))
     return this;
   throw Components.results.NS_NOINTERFACE;
  },

  onLocationChange: function(aProgress, aRequest, aURI)
  {
    myExtension.processNewURL(aURI);
  },

  onStateChange: function(a, b, c, d) {},
  onProgressChange: function(a, b, c, d, e, f) {},
  onStatusChange: function(a, b, c, d) {},
  onSecurityChange: function(a, b, c) {}
};

var myExtension = {
  oldURL: null,

  init: function(e) {
    // Listen for webpage loads

    gBrowser.addProgressListener(myExt_urlBarListener,
        Components.interfaces.nsIWebProgress.NOTIFY_LOCATION);
  },

  uninit: function(e) {
    gBrowser.removeProgressListener(myExt_urlBarListener);
  },

  processNewURL: function(aURI) {
    if (aURI.spec == this.oldURL)
      return;

    // now we know the url is new...
    this.oldURL = aURI.spec;

    var href = aURI.spec;

    var vars = [], hash;
    var hashes = href.slice(href.indexOf('?') + 1).split('&');
    for(var i = 0; i < hashes.length; i++)
    {
        hash = hashes[i].split('=');
        vars.push(hash[0]);
        vars[hash[0]] = hash[1];
    }

    if(vars[0].match(/^http:\/\/www\.google\.fr/))
    {
        //I want use the event e here
        //But it doesn't work
        displayBookmarks(e);
    }
  }
};

//The following doesn't work (I get "e is not defined" in the Error Console) 
window.addEventListener("DOMContentLoaded", function(e) {myExtension.init(e)}, false);
window.addEventListener("unload", function() {myExtension.uninit()}, false);

1 Ответ

0 голосов
/ 05 июля 2011

Не забудьте также добавить параметр в объявление функции:

window.addEventListener("load", function(e) {myExtension.init(e)}, false);
...
init: function(e) {
...