MediaWiki:Gadget-Common-Ajax.js

Un livre de Wikilivres.

Attention : Depuis MediaWiki 1.18 les pages se terminant avec l'extension .js ou .css sont interprétées comme des pages wiki ! En particulier les modèles (subst ou non) et les liens. Vous devez donc migrer le code source et effectuer vos changements en évitant ces éléments de syntaxe wiki (peu importe leurs emplacements dans le code source : commentaire, chaine) :

  • Double accolades ouvrantes (en particulier avec subst:) : séparer les deux accolades "{"+"{" du reste de la chaine
  • Double crochets ouvrants : même technique de séparation.
  • Signature (tildes ~ multiples) : même technique de séparation.

Note : après avoir enregistré vos préférences, vous devrez attendre que le serveur mette à jour la feuille de style globale avant de forcer le rechargement complet du cache de votre navigateur pour voir les changements.

  • Firefox / Safari : Maintenez la touche Maj (Shift) en cliquant sur le bouton Actualiser ou pressez Ctrl-F5 ou Ctrl-R (⌘-R sur un Mac) ;
  • Google Chrome : Appuyez sur Ctrl-Maj-R (⌘-Shift-R sur un Mac) ;
  • Internet Explorer : Maintenez la touche Ctrl en cliquant sur le bouton Actualiser ou pressez Ctrl-F5 ;
  • Konqueror : Cliquez sur Actualiser ou pressez F5 ;
  • Opera : Videz le cache dans Outils → Préférences.
// Chargement asynchrone de pages

function createXhrObject()
{
    if (window.XMLHttpRequest)
        return new XMLHttpRequest();
 
    if (window.ActiveXObject)
    {
        var names = [
            "Msxml2.XMLHTTP.6.0",
            "Msxml2.XMLHTTP.3.0",
            "Msxml2.XMLHTTP",
            "Microsoft.XMLHTTP"
        ];
        for(var i in names)
        {
            try{ return new ActiveXObject(names[i]); }
            catch(e){}
        }
    }
    return null; // non supporté
}

/*
    Chargement de page asynchrone
    Paramètres :
    url     : URL de la page chargée avec Ajax
    f_ok    : fonction appelée en cas de réussite.
              Paramètres :
                - contenu de la page
                - arguments supplémentaires
    f_error : fonction appelée en cas d'échec.
              Paramètres :
                - code d'erreur HTTP (si>0)
                - message d'erreur
                - arguments supplémentaires
    args    : arguments supplémentaires passés
              aux fonctions précédentes.
*/
function async_call(url, f_ok, f_error, args)
{
    var xhr = createXhrObject();
    xhr.open("GET", url, true);
    xhr.setRequestHeader("Pragma", "cache=no");
    xhr.setRequestHeader("Cache-Control", "no-transform");
    xhr.onreadystatechange = function(){
        if (xhr.readyState != 4) return;
        if (xhr.status != 200) f_error(xhr.status, xhr.statusText, args);
        else f_ok(xhr.responseText, args);
    };
    xhr.send();
}