IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

AJAX Discussion :

[AJAX] Afficher un fichier inclus après le chargement de la page


Sujet :

AJAX

  1. #1
    Membre éprouvé

    Inscrit en
    Janvier 2006
    Messages
    969
    Détails du profil
    Informations forums :
    Inscription : Janvier 2006
    Messages : 969
    Points : 958
    Points
    958
    Par défaut [AJAX] Afficher un fichier inclus après le chargement de la page
    Bonjour

    Mon site (CMS maison pour un reporting intranet) a la structure suivante : une page index.php appelle toujours les pages spécifiques à chaque état affiché.
    Ce qui donne, pour la page index.php :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    //début de la page : constantes, variables, fonctions, pré-traitements divers
    include "mapagespecifique.php";
    //fin de la page : post-traitements divers
    Mon problème est que les scripts "mapagespecifique.php" peuvent être assez longs à tourner, et utilisent déjà les buffers de sortie.
    Y a-t-il une solution (utilisant probablement un <div> autour de l'include + js/ajax) pour afficher d'abord le début et la fin de chaque page avec un gif animé d'attente à la place du script spécifique, puis remplacer le gif par le contenu du script ?

  2. #2
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Points : 91 220
    Points
    91 220
    Billets dans le blog
    20
    Par défaut
    Citation Envoyé par guidav Voir le message
    Y a-t-il une solution (utilisant probablement un <div> autour de l'include + js/ajax) pour afficher d'abord le début et la fin de chaque page avec un gif animé d'attente à la place du script spécifique, puis remplacer le gif par le contenu du script ?
    Oui bien sûr et tu as bien cerné le problème
    Ta page principale sera du style :
    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    <!--début de la page : constantes, variables, fonctions, pré-traitements divers-->
    <div id="contenu-dynamique"><img src="loader.gif" alt="Traitement en cours..." /></div>
    <!--fin de la page : post-traitements divers-->
    Je te laisse bien sûr mettre en forme cette div

    Ensuite, au onload de la page :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    window.onload = function(){
        var xhr = getXHR();    // fonction qui crée ton objet XMLHttpRequest
        xhr.open('GET', 'mapagespecifique.php');
        xhronreadystatechange = function(){
            if(xhrreadyState==4 && xhr.status=200){
                document.getElementById('contenu-dynamique').innerHTML = xhr.responseText;
            }
        }
        xhr.send(null);
    }
    Attention cependant à une chose,
    les scripts "mapagespecifique.php" peuvent être assez longs à tourner
    en fonction de ce que tu appelles "long", il sera peut-être nécessaire de configurer le serveur pour maintenir la connexion le temps suffisant pour pouvoir recevoir la réponse...

  3. #3
    Membre éprouvé

    Inscrit en
    Janvier 2006
    Messages
    969
    Détails du profil
    Informations forums :
    Inscription : Janvier 2006
    Messages : 969
    Points : 958
    Points
    958
    Par défaut
    Merci beaucoup pour le coup de main, ça marche presque.
    Il me reste cependant un gros problème : la page est maintenant appelée comme un GET, c'est à dire que toutes les variables que j'ai définies avant (sauf celles en session) ont disparu.
    Y a-t-il un moyen de faire en sorte que mes variables prédéfinies persistent lors d'un appel de page avec xhr.open ?

  4. #4
    Membre éprouvé

    Inscrit en
    Janvier 2006
    Messages
    969
    Détails du profil
    Informations forums :
    Inscription : Janvier 2006
    Messages : 969
    Points : 958
    Points
    958
    Par défaut
    Bon, ça marche pratiquement, mais il reste un problème : est-il possible avec cette commande
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    document.getElementById('contenu-dynamique').innerHTML = xhr.responseText;
    d'insérer du code qui contient des formulaires ? J'ai une erreur dans ce cas, la page refuse de s'afficher, le message est "erreur d'exécution inconnue" (merci IE !).
    Idem si j'essaie d'insérer du code qui comporte un peu d'ajax, mes mises à jour de champs en ajax ne fonctionnent pas non plus.

    Merci de votre aide.

    EDIT : le problème ne se pose qu'avec IE6. Je n'ai pas le choix du navigateur, épargnez-moi les sarcasmes habituels.

  5. #5
    Rédacteur/Modérateur
    Avatar de andry.aime
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    8 391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations forums :
    Inscription : Septembre 2007
    Messages : 8 391
    Points : 15 059
    Points
    15 059
    Par défaut
    Bonjour,

    Ce que je fait moi, c'est d'utiliser un formulaire caché que j'affiche et remplie avec le résultat de la requête AJAX en utilisant un XML ou JSON.

    A+.

Discussions similaires

  1. Réponses: 2
    Dernier message: 12/08/2011, 12h20
  2. Réponses: 7
    Dernier message: 20/04/2010, 16h11
  3. [AJAX] Afficher un fichier que par l'AJAX
    Par langevert dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 15/05/2008, 11h10
  4. Réponses: 3
    Dernier message: 05/06/2007, 17h01
  5. affichage d'une image apres le chargement de la page
    Par Krubi dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 27/04/2006, 16h44

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo