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 éxécuté trop tôt avant fin chargement images - JQuery


Sujet :

AJAX

  1. #1
    Membre habitué
    Homme Profil pro
    Étudiant
    Inscrit en
    Juillet 2011
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Juillet 2011
    Messages : 10
    Par défaut [AJAX] Script éxécuté trop tôt avant fin chargement images - JQuery
    Bonjour à tous,

    je suis actuellement en train de développer une sorte de portfolio avec beaucoup de galeries d'images. J'utilise de l'AJAX via JQuery pour charger dynamiquement ces images contenues dans divers fichiers HTML.

    Une fois ces images chargées, un script "carrousel" s’exécute sur ces images. Malheureusement, les images ne sont complètement pas chargées et le script s' exécute trop tot.

    J'aimerai que le chargement de ces images se finisse avant que le script se lance.

    Voici un bout de mon code:
    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
    22
    23
    24
    25
    26
    27
    $(document).ready (function(){
    	$("#menu a").click(function(e) {
    		e.preventDefault();
    		page = $(this).attr("href");
    		$.ajax ({
    			url: page,
    			cache: false,
    			success: function(html){
    				afficher(html);
    			},
    			error: function(XMLHttpRequest, textStatus, errorThrown) {
    				alert (textStatus);
    			}
    		}) 
    	}); 
    });
     
    function afficher(data){
    	$("#content").fadeOut(500, function(){
    		$("#content").empty();
    		$("#content").append(data).fadeIn(1000);
    		$.getScript('./js/jquery.carousel.min.js', function() {
    			// Utilisation du carousel
    			$("div.foo").carousel({ nextBtn: '<img src="./img/next.png" alt="next" />', prevBtn: '<img src="./img/previous.png" alt="next" />' });
    		});
    	});
    }
    J'ai réussi à faire l'équivalent en statique sans AJAX mais j'aimerai le rendre plus esthétique, d'où AJAX. Sauf si quelqu'un trouve une alternative.

    Voici l'alternative en statique:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    $(document).ready(function(){
    				$("#content").hide(); //on cache le contenu
    				$("body").append('<div id="wait"><img src="../../img/loader.gif" alt="chargement..."/></div>');
    				});
    			// Utilisation du carousel
    				$(window).load(function(){
    					$("#wait").hide();
    					$("#content").fadeIn(1500);
    					$("div.foo").carousel({ dispItems: 2,  nextBtn: '<img src="../../img/next.png" alt="next" />', prevBtn: '<img src="../../img/previous.png" alt="next" />' });
    				});
    Merci d'avance, je bloque depuis pas mal de temps sur ce problème...

  2. #2
    Invité
    Invité(e)
    Par défaut
    Bonjour,
    => jQuery.ajax()

    en traitant Ajax en synchrone ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    		$.ajax ({
    			async : false,
    			// [...]

  3. #3
    Membre habitué
    Homme Profil pro
    Étudiant
    Inscrit en
    Juillet 2011
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Juillet 2011
    Messages : 10
    Par défaut
    Merci pour votre réponse rapide, je vais essayer de me renseigner sur votre proposition ou c'est une question ? xD

  4. #4
    Invité
    Invité(e)
    Par défaut
    C'est à tester.
    (mais une réponse est souhaitée : ça marche ou pas ?)

  5. #5
    Membre habitué
    Homme Profil pro
    Étudiant
    Inscrit en
    Juillet 2011
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Juillet 2011
    Messages : 10
    Par défaut
    Je suis actuellement en train de tester votre proposition. Je vous tiens au courant très prochainement. Merci encore

    MAJ: Les images apparaissent en saccadées. Cela signifie qu'elles sont toujours en train de charger mais le script semble s'effectuer après ! :/


    J'ai tenté de placer un loader en attendant que toutes les images chargent mais il disparaît aussitôt et les images ne sont pas complètement chargées...

    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
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    $(document).ready (function(){
    	$("#menu a").click(function(e) {
    		e.preventDefault();
    		page = $(this).attr("href");
     
    		$.ajax ({
    			url: page,
    			cache: false,
    			async: false,
    			success: function(html){	
    				$("body").append('<div id="wait"><img src="../../img/loader.gif" alt="chargement..."/></div>');
    				afficher(html);
    			},
    			error: function(XMLHttpRequest, textStatus, errorThrown) {
    				alert (textStatus);
    			}
    		}) 
    	}); 
    });
     
    function afficher(data){
    	$("#content").fadeOut(500, function(){
    		$("#content").empty();
    		$("#content").append(data);
    		$("#wait").hide();
    		$("#content").fadeIn(1500);
    		$.getScript('./js/jquery.carousel.min.js', function() {
    			// Utilisation du carousel
    			$("div.foo").carousel({ nextBtn: '<img src="./img/next.png" alt="next" />', prevBtn: '<img src="./img/previous.png" alt="next" />' });
    		});
    	});
    }

  6. #6
    Membre habitué
    Homme Profil pro
    Étudiant
    Inscrit en
    Juillet 2011
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Juillet 2011
    Messages : 10
    Par défaut
    Donc à priori, cela ne semble pas marcher à moins que je sois dans l'erreur

Discussions similaires

  1. Réponses: 6
    Dernier message: 18/04/2012, 14h57
  2. Réponses: 1
    Dernier message: 15/07/2011, 12h40
  3. [AJAX] script de chargement en bas de page
    Par identifiant_bidon dans le forum AJAX
    Réponses: 0
    Dernier message: 07/06/2011, 14h55
  4. [MySQL] problème de script qui s'arrête avant la fin
    Par sorciervoyageur dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 28/05/2009, 10h19
  5. [AJAX] Détecter fin de chargement images
    Par hugo69 dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 13/11/2008, 18h31

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