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

jQuery Discussion :

Requête AJAX, blocage sous IE/chrome/safari


Sujet :

jQuery

  1. #1
    Membre habitué
    Profil pro
    Étudiant
    Inscrit en
    Janvier 2009
    Messages
    142
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2009
    Messages : 142
    Points : 154
    Points
    154
    Par défaut Requête AJAX, blocage sous IE/chrome/safari
    Bonjours à tous,

    J'utilise Jquery & Jquery UI, Je souhaite faire une progressbar qui indiquer la progression d'upload de fichier.

    voici mon bout de 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
    for (i = 0 ; i < uploadQueue.length ; i++)
    	{	
    		uploadQueue[i] = uploadQueue[i].replace(/::/, "."); 
    		uploadQueue[i] = uploadQueue[i].replace(/:/, "/"); 
     
     
    		$.ajax({
    			async:false,
    			type: "POST",
    			url: domain+"/actions/elements/arborescence/action/upload.php",
    			data: "Queue="+uploadQueue[i],
    			success: function(msg)
    			{	
     
     
     
     
    			}	
    		});
     
    	}
    En clair, je fait un boucle sur la queue de fichier à uploader puis pour chaque fichier j'effectue une requete vers le fichier php qui va uploader le fichier.

    Le probleme ce situe au niveau de la progression de la progressbar. En effet on voit clairement defiler la barre sous FF, mais sous IE CHROME et SAFARI, j'ai l'impression qu'il envoie toutes les requetes puis affiche directement la bar a 100%. En gros sa bloque le navigateur pendant un certain temps et affiche a la fin 100%, ce qui n'est pas l'effet voulu.

    Merci de votre aide, cordialement Funk.

    PS : le async:false est vonlontaire car j'ai pas envie de lancer 100 fichier en upload casi en meme temps.

  2. #2
    Membre du Club
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    59
    Détails du profil
    Informations personnelles :
    Âge : 44
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations forums :
    Inscription : Janvier 2007
    Messages : 59
    Points : 57
    Points
    57
    Par défaut
    Je ne vois aucun code à propos de la progress bar, tu peux nous le montrer ou tout du moins nous expliquer ton algorithme?

  3. #3
    Membre habitué
    Profil pro
    Étudiant
    Inscrit en
    Janvier 2009
    Messages
    142
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2009
    Messages : 142
    Points : 154
    Points
    154
    Par défaut
    Oui désolé j'avais pas mit le code complet, le voici :

    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
     
    for (i = 0 ; i < uploadQueue.length ; i++)
    	{	
    		uploadQueue[i] = uploadQueue[i].replace(/::/, "."); 
    		uploadQueue[i] = uploadQueue[i].replace(/:/, "/"); 
     
    		$.ajax({
    			async:false,
    			type: "POST",
    			url: domain+"/actions/elements/arborescence/action/upload.php",
    			data: "Queue="+uploadQueue[i],
    			success: function(msg)
    			{	
    				totalRestant += uploadSize[i];
    				percent = ((totalRestant*100)/totalSize);
     
    				$("#progressbar").progressbar({ value: percent });
    				$("#pourcentage").html(percent+"%");				
    			}	
    		});
     
    	}

  4. #4
    Membre averti Avatar de sayari.dev
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mai 2010
    Messages
    142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Mai 2010
    Messages : 142
    Points : 300
    Points
    300
    Par défaut
    Bonjour,

    Il faut enlever l'option async ou la mettre à true

    Plus d'infos sur la fonction ajax de jQuery : http://api.jquery.com/jQuery.ajax/

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    59
    Détails du profil
    Informations personnelles :
    Âge : 44
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations forums :
    Inscription : Janvier 2007
    Messages : 59
    Points : 57
    Points
    57
    Par défaut
    Il faut savoir que sous IE, les requêtes Ajax synchrones font "frizzer" le navigateur.

    Je te conseille:
    - soit de mettre un délaie entre chaque requête Ajax (au cas où IE n'ait pas eu le temps tout simplement de rafraichir ta barre de progression),
    - soit de séquentialiser tes appels Ajax (ie. de faire des requêtes Ajax asynchrone et d'appeler le prochaine upload dans le onsuccess)

  6. #6
    Membre habitué
    Profil pro
    Étudiant
    Inscrit en
    Janvier 2009
    Messages
    142
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2009
    Messages : 142
    Points : 154
    Points
    154
    Par défaut
    Le soucis c'est que je souhaite justement que mes requête soit synchrone pour ne pas lancer 100 upload de fichier en meme temps.

    Je n'arrive pas a trouver la raison pour laquelle cela fonctionnement parfaitement sous FF et pas sur safari/ie/chrome.

    Citation Envoyé par Mohicane Voir le message
    Il faut savoir que sous IE, les requêtes Ajax synchrones font "frizzer" le navigateur.

    Je te conseille:
    - soit de mettre un délaie entre chaque requête Ajax (au cas où IE n'ait pas eu le temps tout simplement de rafraichir ta barre de progression),
    - soit de séquentialiser tes appels Ajax (ie. de faire des requêtes Ajax asynchrone et d'appeler le prochaine upload dans le onsuccess)
    Merci te ta réponse, je me doutais bien que le navigateur y était pour quelque chose. Je vais donc revoir la conception.

Discussions similaires

  1. Erreur JavaScript sous Chrome, Safari et IE8
    Par hsii04 dans le forum IGN API Géoportail
    Réponses: 16
    Dernier message: 04/07/2010, 12h26
  2. Requête ajax chrome/safarie
    Par spy74 dans le forum jQuery
    Réponses: 3
    Dernier message: 24/05/2010, 12h47
  3. Décalage sous Firefox & IE ; pas de décalage sous Google Chrome & Safari
    Par Fya34 dans le forum Balisage (X)HTML et validation W3C
    Réponses: 3
    Dernier message: 09/02/2010, 16h45
  4. [AJAX] Ajax sous IE et safari
    Par Invité dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 29/05/2008, 09h22
  5. [AJAX] Résultat de requête Ajax vide sous IE, mais pas sous FF
    Par brazilia28 dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 14/09/2007, 16h18

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