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 :

Changer le contenu d'un élément en plusieurs étapes


Sujet :

jQuery

  1. #1
    Membre régulier
    Inscrit en
    Janvier 2005
    Messages
    104
    Détails du profil
    Informations forums :
    Inscription : Janvier 2005
    Messages : 104
    Points : 123
    Points
    123
    Par défaut Changer le contenu d'un élément en plusieurs étapes
    Salut à tous,

    J'ai une fonction assez simple, qui fait 3 choses séquentiellement :
    1. appeler un code serveur avec ajax(), qui renvoie un tableau HTML (<table>)
    2. insérer le tableau HTML reçu dans un elément du document
    3. appliquer une fonction au tableau (un plug-in jquery, tablesorter : http://tablesorter.com/docs/ , qui va rendre le tableau triable en cliquant sur les entêtes). Cette fonction va changer le tableau (insertion de styles et d'events).

    Voici un pseudo code :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    $.ajax({
    	   type: "GET",				   
    	   url: myURL,
    	   dataType: "html",				   
    	   success: function(data){		 
    		 $("#myDiv").html(data);
    		 $("table").tablesorter();		 
    	   }
    	 });
    Ca fonctionne bien, cependant quand le tableau est grand, la fonction tablesorter() est relativement lente.

    Ce que je voudrais, c'est d'abord afficher le tableau immédiatement, sans tablesorter, puis appliquer tablesorter. Le but est de rendre l'appli plus agréable, tout simplement.

    Le problème est que javascript ne va changer l'affichage qu'après que la fonction tablesorter soit appliquée. En mettant un alert('hello') entre
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $("#myDiv").html(data);
    et
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $("table").tablesorter();
    ça le fait bien en deux fois, mais bien sûr ce n'est pas intéressant comme solution. Est-ce que quelqu'un saurait comment faire ça en deux étapes de façon transparente pour l'utilisateur ?

  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 : 53
    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 418
    Points
    91 418
    Billets dans le blog
    20
    Par défaut
    Ce que je voudrais, c'est d'abord afficher le tableau immédiatement, sans tablesorter, puis appliquer tablesorter.
    Ben c'est ce que tu fais actuellement si j'en crois ton code
    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 régulier
    Inscrit en
    Janvier 2005
    Messages
    104
    Détails du profil
    Informations forums :
    Inscription : Janvier 2005
    Messages : 104
    Points : 123
    Points
    123
    Par défaut
    Oui, dans le code c'est séquentiel, mais à l'affichage tout se fait en une fois.

    Par exemple, si afficher la table prend 1 seconde et appliquer la fonction de tri prend 3 secondes, la fonction va afficher la table directment avec les boutons de tri, après 4 secondes. Ce que je voudrais c'est qu'il affiche d'abord la table brute après 1 seconde, puis la table avec les boutons de tri 3 secondes plus tard.

    Je ne sais pas trop pourquoi - j'imagine que Javascript anticipe que la fonction de tri va elle aussi toucher à la table, et affiche tout d'un coup.

  4. #4
    Rédacteur

    Avatar de danielhagnoul
    Homme Profil pro
    Étudiant perpétuel
    Inscrit en
    Février 2009
    Messages
    6 389
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 73
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant perpétuel
    Secteur : Enseignement

    Informations forums :
    Inscription : Février 2009
    Messages : 6 389
    Points : 22 933
    Points
    22 933
    Billets dans le blog
    125
    Par défaut
    Bonsoir

    Vous pouvez utiliser setTimeout pour différer l'application du plug-in Tablesorter, exemple pour 4s :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    setTimeout(function(){
    	$("table").tablesorter();
    }, 4000);

    Blog

    Sans l'analyse et la conception, la programmation est l'art d'ajouter des bogues à un fichier texte vide.
    (Louis Srygley : Without requirements or design, programming is the art of adding bugs to an empty text file.)

  5. #5
    Rédacteur
    Avatar de Arnaud F.
    Homme Profil pro
    Développeur COBOL
    Inscrit en
    Août 2005
    Messages
    5 183
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France

    Informations professionnelles :
    Activité : Développeur COBOL
    Secteur : Finance

    Informations forums :
    Inscription : Août 2005
    Messages : 5 183
    Points : 8 873
    Points
    8 873
    Par défaut
    Bonjour

    une autre manière de faire serait de voir s'il n'est pas possible d'optimiser votre méthode de tri de la table.

    Peut-on avoir le code de la fonction tableSorter?
    C'est par l'adresse que vaut le bûcheron, bien plus que par la force. Homère

    Installation de Code::Blocks sous Debian à partir de Nightly Builds

  6. #6
    Membre régulier
    Inscrit en
    Janvier 2005
    Messages
    104
    Détails du profil
    Informations forums :
    Inscription : Janvier 2005
    Messages : 104
    Points : 123
    Points
    123
    Par défaut
    Merci à vous deux. Le timer est une solution oui. On pourrait même faire 2 timers, un après 2 secondes, et un autre après 4 secondes qui lancerait le tri seulement si ça n'a pas encore été fait.

    Pour le code du plug-in tablesorter, ce n'est pas moi qui l'ait fait, il se trouve ici : http://tablesorter.com/docs/ (c'est open source).
    J'aime bien ce plug-in, il est très simple à utiliser et assez léger. Mais il est lent sur les grandes tables (plusieurs centaines de lignes).

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 9
    Dernier message: 10/12/2009, 19h03
  2. Réponses: 11
    Dernier message: 15/04/2005, 15h42
  3. [JList] changer la couleur d'UN élément
    Par youb dans le forum Composants
    Réponses: 1
    Dernier message: 31/03/2005, 11h31
  4. TD changer le contenu
    Par C.M dans le forum Général JavaScript
    Réponses: 5
    Dernier message: 18/02/2005, 13h51
  5. [Swing] Changer le contenu d'un Container via un menu
    Par TheSeb dans le forum AWT/Swing
    Réponses: 2
    Dernier message: 07/12/2004, 23h07

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