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] Script Javascript Galleria + Raffraichissement zone en Ajax


Sujet :

AJAX

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre du Club
    Homme Profil pro
    Inscrit en
    Août 2011
    Messages
    9
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations forums :
    Inscription : Août 2011
    Messages : 9
    Par défaut [AJAX] Script Javascript Galleria + Raffraichissement zone en Ajax
    Bonjour à toutes et à tous,
    Ayant parcouru et re-parcouru mes sources, je ne parviens pas à résoudre le problème que je rencontre.

    Je suis en train de réaliser un projet que j'ai depuis quelques temps déjà. Pour cela, je combine l'utilisation d'Ajax pour le raffraichissement du contenu et le script Galleria pour mettre en place une galerie photo souple.

    Le raffraichissement du contenu via le menu fonctionne correctement en AJAX. Là dessus, je n'ai rencontré aucun soucis. En revanche, la galerie photo ne s'affiche plus sous forme de miniatures mais les photos s'affichent normalement.

    Pour charger le fichier, j'utilise XHRConnection.
    Existe-t-il une incompatibilité entre l'utilisation des deux technologies (Ajax et JS) ? Cela me parait étrange malgré tout.

    Par contre, le comble, c'est que lorsque je vais sur la page en chemin absolu (via url), la galerie fonctionne comme il se doit.

    J'avoue être perdu.
    Quelqu'un a-t-il déjà été confronté à ce genre de soucis ?

    Merci,
    Laurent.

    J'utilise Galleria telle qu'elle est http://galleria.aino.se/download/
    Fonction ajoutée à la fin du JS
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    function chargeFichier(nb) {
    	var XHR = new XHRConnection();
    	XHR.setRefreshArea('corps');
            if(nb==1){XHR.sendAndLoad("accueil.php", "GET");}
            if(nb==2){XHR.sendAndLoad("galerie.php", "GET");}
            if(nb==3){XHR.sendAndLoad("cv.php", "GET");}
    	return true;
    Et voici le code du fichier galerie.php
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    <html>
        <head>
            <script src="http://ajax.googleapis.com/ajax/libs/jquery/1/jquery.js"></script>
            <script src="galerie/galleria-1.2.5.min.js"></script>
        </head>
        <body>
            <div class="entete-rub"><span class="entete-rub-lettrine">G</span>alerie</div>
            <div id="gallery">
                <img src="galerie/photo1.jpg">
                <img src="galerie/photo2.jpg">
                <img src="galerie/photo3.jpg">
            </div>
            <script>
                Galleria.loadTheme('galerie/themes/classic/galleria.classic.min.js');
                $("#gallery").galleria({
                    width: 500,
                    height: 500
                });
            </script>
        </body>
    </html>

  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 : 55
    Localisation : France, Gironde (Aquitaine)

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

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Billets dans le blog
    20
    Pas de question technique par MP !
    Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
    Mes formations video2brain : La formation complète sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
    Mon livre sur jQuery
    Module Firefox / Chrome d'intégration de JSFiddle et CodePen sur le forum

  3. #3
    Membre du Club
    Homme Profil pro
    Inscrit en
    Août 2011
    Messages
    9
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations forums :
    Inscription : Août 2011
    Messages : 9
    Par défaut Résolution
    Bonjour,
    J'ai trouvé une solution à mon problème. Peut-être n'est-elle pas la meilleure, mais elle fonctionne comme je le souhaite.

    Pour ceux qui serait dans le même cas que moi, j'ai remplacé l'instruction liée à mon onglet-menu galerie comme suit

    Ancien code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    function chargeFichier(nb) {
    	var XHR = new XHRConnection();
    	XHR.setRefreshArea('corps');
            if(nb==1){XHR.sendAndLoad("accueil.php", "GET");}
            if(nb==2){XHR.sendAndLoad("galerie.php", "GET");}
            if(nb==3){XHR.sendAndLoad("cv.php", "GET");}
    	return true;
    }
    Nouveau code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    function chargeFichier(nb) {
    	var XHR = new XHRConnection();
    	XHR.setRefreshArea('corps');
            if(nb==1){XHR.sendAndLoad("accueil.php", "GET");}
            if(nb==2){document.location.href="index.php?galerie";}
            if(nb==3){XHR.sendAndLoad("cv.php", "GET");}
    	return true;
    }
    et j'ai ajouté un simple

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <?php if(isset($_GET['galerie'])){ include('galerie.php');} ?>
    dans ma page d'accueil, de cette manière, le javascript de la galerie est exécuté malgré tout.

    Je répète que ce n'est pas forcément ce qu'il y a de plus propre, mais cela reste fonctionnel.

  4. #4
    Expert confirmé
    Avatar de Auteur
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    7 660
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 7 660
    Par défaut
    bonjour,

    pour avoir discuté avec laurent__ sur le chat, je voudrais ajouter un complément d'information sur son problème.

    Comme il l'a indiqué dans son premier message le fichier qu'il appelle par une requête ajax est galerie.php qui contient dans le code ces balises scripts :
    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
            <script>
                Galleria.loadTheme('galerie/themes/classic/galleria.classic.min.js');
                $("#gallery").galleria({
                    width: 500,
                    height: 500
                });
            </script>


    Malheureusement, ce bout de code n'est pas exécuté après l'envoi de la requête AJAXif(nb==2){XHR.sendAndLoad("galerie.php", "GET");} (c'est considéré comme du texte).

    La solution pour laurent__ serait donc d'inclure le script contenu dans galerie.php dans une fonction qui serait ensuite appelée après l'exécution de la requête AJAX (une fonction callback).

    N'étant pas familier avec AJAX et ne connaissant pas la bibliothèque XHRConnection.js utilisée ici pour la gestion de l'objet XHR, je n'ai pas pu l'aider sur ce point.

    Si vous avez donc des idées pour résoudre ce problème (qu'il a certes résolu d'une autre manière) tout en utilisant AJAX n'hésitez pas à poster votre solution

Discussions similaires

  1. [AJAX] Script .js dans le <head> via Ajax?
    Par dqniel dans le forum AJAX
    Réponses: 3
    Dernier message: 17/05/2011, 14h37
  2. Réponses: 1
    Dernier message: 25/11/2010, 10h33
  3. [AJAX] page d'attente là 'aide d'un script javascript
    Par babalastar dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 05/03/2007, 21h12
  4. [Ajax] Execution d'un script javascript dans le fichier xml
    Par tonioz dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 30/06/2006, 08h00
  5. [AJAX] Script Javascript et Ajax
    Par Azanael dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 27/05/2006, 22h48

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