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

JavaScript Discussion :

[Performance] Afficher/Masquer une colonne


Sujet :

JavaScript

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2011
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Service public

    Informations forums :
    Inscription : Mai 2011
    Messages : 20
    Par défaut [Performance] Afficher/Masquer une colonne
    Bonjour à tous,

    Vous allez surement vous dire que c'est du vu et du re-vu mais mon problème ce n'est pas d'afficher ou de masquer les colonnes, j'utilise un simple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    getElementById('id').style.display = "none"
    dans une boucle for.

    Le problème c'est que je dois masquer une colonne pour un tableau d'environ 2000 lignes (minimum) et le fait d'utiliser cette boucle me prend à peut près 30 secondes pour tout afficher.

    Je me demandais si il n'y aurait pas une autre solution plus rapide?
    J'ai fait le tour de beaucoup de solutions mais aucune ne ralenti vraiment le temps d'affichage.

    Merci d'avance

  2. #2
    Rédacteur
    Avatar de bigboomshakala
    Homme Profil pro
    Consultant Web .NET
    Inscrit en
    Avril 2004
    Messages
    2 077
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Consultant Web .NET
    Secteur : Finance

    Informations forums :
    Inscription : Avril 2004
    Messages : 2 077
    Par défaut
    salut

    1ère optimisation : ne pas faire getElementById à chaque fois...

    par exemple à la fin du chargement de ta page :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    var elts = [];
    for (ma boucle){
      elts.push(document.getElementById('mon_id' + i));
    }
     
    /* 
    tu remplis le tableau comme tu veux. si tu utilises jQuery c'est encore plus simple, elts = $('.toto') avec toto un css que tu mets sur les éléments à masquer/afficher, ou tu peux choisir un autre sélecteur
    */
    par la suite tu boucles sur le tableaux des éléments, ce qui peut être 'achement plus rapide si le DOM de ta page est gros.

  3. #3
    Membre averti
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2011
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Service public

    Informations forums :
    Inscription : Mai 2011
    Messages : 20
    Par défaut
    Merci beaucoup de cette réponse rapide,

    Je ne vois pas trop comment utiliser ta var elts

  4. #4
    Rédacteur
    Avatar de bigboomshakala
    Homme Profil pro
    Consultant Web .NET
    Inscrit en
    Avril 2004
    Messages
    2 077
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Consultant Web .NET
    Secteur : Finance

    Informations forums :
    Inscription : Avril 2004
    Messages : 2 077
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    function toggle(show){
      var i, n;
      for (i=0, n=elts.length; i<n; i++){
        elts[i].style.display = show ? null : "none"; 
       // ou "block" ou "inline" à la place de null
       // suivant ce que tu veux
      }
    }

  5. #5
    Membre averti
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2011
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Service public

    Informations forums :
    Inscription : Mai 2011
    Messages : 20
    Par défaut
    Oki, je comprend beaucoup mieux, je test ça dès que je peut et je vous tient au courant.

    Merci beaucoup !

  6. #6
    Membre averti
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2011
    Messages
    20
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Service public

    Informations forums :
    Inscription : Mai 2011
    Messages : 20
    Par défaut
    Voici un script vraiment performant (environ 1s a la place des 30 du départ) :

    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
     
    var etat=1;
        var i;
        var affBlock= "block";
        var affNone= "none";
     
        function affichageCheckbox() {
     
            var lstIdCheckbox= document.getElementsByName("id_checkbox");
            var nombreLigne= checkbox.length;
     
            if (etat == 1) {
                for (i=0; i<(nombreLigne); i++) {
                    lstIdCheckbox[i].style.display = affBlock;
                }
                etat=0;
            } else {
                for (i=0; i<(nombreLigne); i++) {
                    lstIdCheckbox[i].style.display = affNone;
                }
                etat=1;
            }
        }
    Voila j'espere que sa aidera du monde !!!

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

Discussions similaires

  1. Afficher/Masquer une colonne d'un tableau
    Par Budy123 dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 16/12/2011, 15h50
  2. [Jasper Report] Masquer une colonne
    Par BiM dans le forum Jasper
    Réponses: 4
    Dernier message: 28/03/2006, 15h04
  3. [Form] Afficher/Masquer une zone de texte
    Par SpyesX dans le forum IHM
    Réponses: 14
    Dernier message: 01/12/2005, 01h13
  4. [JTable] Masquer une colonne
    Par IvanPopov dans le forum Composants
    Réponses: 2
    Dernier message: 26/07/2005, 17h12

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