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 :

Navigation ajax lente (5 secondes de délai)


Sujet :

AJAX

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    162
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 162
    Par défaut Navigation ajax lente (5 secondes de délai)
    Bonjour,
    j'ai mis sur mon site la navigation en ajax en faisant comme ceci:

    html:
    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    <a href="url" class="ajax"> Lien1 </a>

    javascript:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
            $(".ajax").bind("click",function(){
                var url=$(this).attr('href');
                $.get(url,{},function(data){
     
                    $(".content").empty().append(data);
                    history.pushState(null,null,url);
               }
              }
    Ca a tjrs trés bien fonctionné.
    Mais depuis quelque temps maintenant, mes requêtes sont systématiquement bloqué 5000ms à la réception. Quelque soit le type de page, ça coince toujours au même endroit...auriez vous une idée??

    Merci par avance

  2. #2
    Modérateur

    Avatar de NoSmoking
    Homme Profil pro
    Inscrit en
    Janvier 2011
    Messages
    17 198
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 17 198
    Par défaut
    Bonjour,
    Quelque soit le type de page, ça coince toujours au même endroit.
    Certes mais lequel ?

    Comme tu utilises un lien, <a>, pour lancer ta commande, il te faut inhibé le comportement par défaut de celui-ci
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    $(".ajax").bind("click",function(event){
        // inhibe le comportement par défaut
        event.preventDefault();
    peut-être même que ton history.pushState(null,null,url) ne servira plus à rien.

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    162
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 162
    Par défaut
    Bonjour
    ça coince systématiquement sur la réception avec un délai toujours proche de 5 secondes

    Nom : xhr.JPG
Affichages : 318
Taille : 28,3 Ko

  4. #4
    Invité
    Invité(e)
    Par défaut
    Bonjour,

    1-.bind() est déprécié. Il faut utiliser .on().

    2- .empty().append(...) : si on veur juste remplacer par du code html, .html(...) convient et suffit.

    Donc :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    	$("a.ajax").on("click",function(event){
    		event.preventDefault(); // inhibe le comportement par défaut
    		var url = $(this).attr('href');
    		$.get(url,{},function(data){
    			$(".content").html(data);
    			history.pushState(null,null,url);
    		}
    	}
    N.B. ".content" : si c'est un conteneur UNIQUE, il vaudrait mieux utiliser un id.

  5. #5
    Membre confirmé
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    162
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 162
    Par défaut
    Salut,
    merci j'ai fait les changements .on(), html() et preventDefault()

    Par contre ça ne change rien au niveau de la réception
    Nom : xhr_chrome.JPG
Affichages : 301
Taille : 33,1 Ko

  6. #6
    Invité
    Invité(e)
    Par défaut
    Comme on ne sait rien du fichier importé, on ne peut rien dire de plus.

  7. #7
    Membre confirmé
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    162
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 162
    Par défaut
    Le fichier importé n'a rien de particulier,
    ça le fait sur n'importe quelle page du site, ça à toujours trés bien fonctionné et du jour au lendemain la navigation est devenu bloqué 5 secondes.

    Sachant qu'en local ça fonctionne trés bien, j'ai pas ce deadlock.

    Voici par exemple une vue que je charge en ajax:

    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
     
    <?php 
    $points=0.0;
     ?> 
     
    <div class="row">
     
      	<div class="col-md-6">
      		<div class="panel panel-warning" >
    			<div class="panel-heading">Informations</div>
     
    			<p style="padding:5px;">Vous devez avoir suffisamment de points dans votre cagnotte pour pouvoir remonter des annonces. Vous avez actuellement <span class='text-info' style='font-weight: bold;'><?php echo $points; ?> points </span> dans votre cagnotte.
    			</p>
     
    			<p style="padding:5px;" class="text-warning">
    				<strong>Attention: </strong> blablabla mon texte
    			</p>
     
    		</div>
    	</div>
     
    </div>

Discussions similaires

  1. Réponses: 2
    Dernier message: 12/01/2010, 13h53
  2. Réponses: 4
    Dernier message: 02/12/2009, 20h27
  3. Ajax lent ! (sortable)
    Par roduce dans le forum Ruby on Rails
    Réponses: 1
    Dernier message: 27/10/2009, 13h39
  4. [Prototype] La navigation ajax
    Par Jerome38190 dans le forum Bibliothèques & Frameworks
    Réponses: 3
    Dernier message: 17/11/2008, 21h43
  5. [AJAX] navigation ajax (aide)
    Par speedylol dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 30/10/2006, 14h39

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