2010-01-27 4 views
0

J'utilise le nsIWebProgressListenerinterface pour savoir si une URL a été modifiée. Si c'est le cas, j'aimerais réécrire le lien. Voici un extrait (code tiré à partir du bas de la page à partir du lien ci-dessus)window.location.replace dans firefox addon supprime tout le chrome!


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() { 
    // Listen for webpage loads 
    gBrowser.addProgressListener(myExt_urlBarListener, 
     Components.interfaces.nsIWebProgress.NOTIFY_LOCATION); 
    }, 

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

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

    // now we know the url is new... 
    start_work(aURI.spec); 
    this.oldURL = aURI.spec; 
    } 
}; 

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

Et une fonction pour gérer le changement:


function start_work(url) 
{ 
    result = check(url); 
    if (result) { 
      setCookie('bws', 'true', 1, '/'); 
      window.location = result; // or window.location.replace, doesn't matter 
     } 
} 

Voici ce qui se passe! alt text http://grab.by/20eP Comme vous pouvez voir l'ensemble du navigateur/barre d'adresse/chrome a disparu!

Vous avez de l'aide?

+0

est-chorme une faute de frappe pour le chrome? –

Répondre

2

simple: ajouter window.content.location

+1

Oui. Dans ce cas, son code est dans le contexte chrome, donc la fenêtre pointe vers la fenêtre chrome qui est l'interface utilisateur du navigateur. – sdwilsh