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 du "Tout cocher"


Sujet :

JavaScript

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    106
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 106
    Points : 76
    Points
    76
    Par défaut Performance du "Tout cocher"
    Bonjour,

    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
    function cocherOuDecocher() {
    	if (document.getElementById("toutcocher").checked == true)  {
    		
    		<%for (int i=0;i<data.length;i++) {%>
    			
    			if (document.getElementById("valide"+<%=i%>) != null) {
    				document.getElementById("valide"+<%=i%>).checked = true;
    			}
    		<%}%>
    	}
    	else {
    		<%for (int i=0;i<data.length;i++) {%>
    			if (document.getElementById("valide"+<%=i%>) != null) {
    				document.getElementById("valide"+<%=i%>).checked = false;
    			}
    			
    		<%}%>
    	}
    }
    Cette fonction fonctionne !
    Mon problème est que le nombre de checkbox peut être variable. Et quand on atteint les 200 checkboxs, ça prend environ 5 secs à tout cocher. Je voulais donc savoir si ma fonction pouvait avoir un problème de performance ou si il y avait peut être qqch à faire pour que ça soit un peu plus rapide.

    Merci

  2. #2
    Membre émérite
    Inscrit en
    Septembre 2002
    Messages
    2 307
    Détails du profil
    Informations forums :
    Inscription : Septembre 2002
    Messages : 2 307
    Points : 2 814
    Points
    2 814
    Par défaut
    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
    function cocherOuDecocher() {
    	checkValue=document.getElementById("toutcocher").checked ;
    	for(i=0;i<<%data.length%>;i++){
    		champ=document.getElementById("valide"+i);
    		if(champ){
    		champ.checked =checkValue
    		}		
    	}	
    }
    //ou
     
    function cocherOuDecocher() {
    	checkValue=document.getElementById("toutcocher").checked ;
    	i=0;
    	champ=document.getElementById("valide"+i);
    	while(champ){		
    		champ.checked =checkValue
    		i++;
    		champ=document.getElementById("valide"+i);
    	}	
    }

  3. #3
    Membre averti Avatar de danyboy85
    Homme Profil pro
    Développeur Java
    Inscrit en
    Décembre 2005
    Messages
    548
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur Java

    Informations forums :
    Inscription : Décembre 2005
    Messages : 548
    Points : 312
    Points
    312
    Par défaut
    Mmm... Je ne pense pas que tu vas pouvoir améliorer la performance de cette fonction de manière significative, surtout avec 200 checkbox dans ta page.

    Ce que je peux te conseiller, c'est soit :

    - d'afficher un texte "Veuillez patienter..." durant l'exécution de la fonction pour ne pas dérouter l'utilisateur (l'utilisateur acceptera la lenteur d'une fonction s'il en est informé)

    - ou de faire en sorte de ne jamais dépasser un nombre défini de checkbox dans ta page. Si par exemple ces checkbox sont dans un tableau, utiliser un pager (tableau avec plusieurs pages [Premier] 1,2,3.....26 [Dernier]), mais c'est beaucoup plus fastidieux à mettre en place.

  4. #4
    Expert confirmé
    Avatar de le_chomeur
    Profil pro
    Développeur informatique
    Inscrit en
    Février 2006
    Messages
    3 653
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 3 653
    Points : 4 835
    Points
    4 835
    Par défaut
    tu peux essayer ceci ;-)

    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
    33
    34
    35
    36
    37
    38
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>Document sans nom</title>
    <script type="text/javascript">
    	function cocherOuDecocher() {
    		var etat = (document.getElementById("valide").checked) ? true:false;
    		var nbElement = document.getElementById('listeCheckbox').getElementsByTagName('input');
    		if(etat){
    			for(var i = 0 , l = nbElement.length ; i <l ; i++){
    				if (nbElement[i].type == 'checkbox') {
    					nbElement[i].checked = etat;
    				}
    			}
    		}
    	}
     
    function creerCheckBox(nombre){
    	document.getElementById('listeCheckbox').innerHTML = '';
    	for(var i = 0 ; i < nombre ; i++){
    		var inputcheck = document.createElement("input");
    		inputcheck.type= 'checkbox';
    		document.getElementById('listeCheckbox').appendChild(inputcheck);
    	}
    }
    </script>
    </head>
     
    <body>
    <input type="checkbox" value="toto" onclick="cocherOuDecocher()" id="valide" />
    <input type="text" value="100" id="nbCheck" /><input type="button" value="créer" onclick="creerCheckBox(document.getElementById('nbCheck').value)" />
    <hr />
    <div id="listeCheckbox">
     
    </div>
    </body>
    </html>
    pour 5000 champs je met 2 secondes environ ( je peux rajouter un benchmark au code si ça vous intéresse ... )

  5. #5
    Membre du Club Avatar de SweetLeaf
    Profil pro
    Inscrit en
    Juillet 2008
    Messages
    151
    Détails du profil
    Informations personnelles :
    Âge : 35
    Localisation : France, Nord (Nord Pas de Calais)

    Informations forums :
    Inscription : Juillet 2008
    Messages : 151
    Points : 55
    Points
    55
    Par défaut
    Pas mal du tout le_chomeur !! Mes respect
    J'en avais fait une aussi mais pas si rapide ^^
    Ca m'interesse pas mal, mais c'est quoi un benchmark ?

  6. #6
    Membre averti Avatar de danyboy85
    Homme Profil pro
    Développeur Java
    Inscrit en
    Décembre 2005
    Messages
    548
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur Java

    Informations forums :
    Inscription : Décembre 2005
    Messages : 548
    Points : 312
    Points
    312
    Par défaut
    Citation Envoyé par danyboy85 Voir le message
    Mmm... Je ne pense pas que tu vas pouvoir améliorer la performance de cette fonction de manière significative, surtout avec 200 checkbox dans ta page.
    Désolé de mettre avancé aussi vite, je ne pensais pas que vos modifications pouvaient avoir un tel impact sur les performances d'exécution de la fonction.

  7. #7
    Expert confirmé
    Avatar de le_chomeur
    Profil pro
    Développeur informatique
    Inscrit en
    Février 2006
    Messages
    3 653
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 3 653
    Points : 4 835
    Points
    4 835
    Par défaut
    lol pas de mal

    un benchmark c'est en gros une fonction te permettant d'évaluer quelque chsoe , dans notre cas ce sera le temps d'exécution

    en gros :

    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
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
     
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>Document sans nom</title>
    <script type="text/javascript">
    	function cocherOuDecocher(optimise) {
    		var Debut = new Date();
    		var etat = (document.getElementById("valide").checked) ? true:false;
    		var etat = (document.getElementById("valide2").checked) ? true:false;
     
    		var nbElement = document.getElementById('listeCheckbox').getElementsByTagName('input');
    		if(optimise){
    				for(var i = 0 , l = nbElement.length ; i <l ; i++){
    					if (nbElement[i].type == 'checkbox') {
    						nbElement[i].checked = etat;
    					}
    				}
    			}
    			else{
    				for(var i = 0 ; i <nbElement.length  ; i++){
    					if (nbElement[i].type == 'checkbox') {
    						nbElement[i].checked = etat;
    					}
    				}
     
    			}
    			var Fin = new Date();
    			alert(Fin-Debut+ "ms");
     
    	}
     
    function creerCheckBox(nombre){
    	document.getElementById('listeCheckbox').innerHTML = '';
    	for(var i = 0 ; i < nombre ; i++){
    		var inputcheck = document.createElement("input");
    		inputcheck.type= 'checkbox';
    		document.getElementById('listeCheckbox').appendChild(inputcheck);
    	}
    }
    </script>
    </head>
     
    <body>
    <input type="radio" value="toto" onclick="cocherOuDecocher(true)" name="titi" id="valide" /> optimisé <input type="radio" value="toto" onclick="cocherOuDecocher(false)" id="valide2"  name="titi"/> non optimisé 
    <input type="text" value="100" id="nbCheck" /><input type="button" value="créer" onclick="creerCheckBox(document.getElementById('nbCheck').value)" />
    <hr />
    <div id="listeCheckbox">
     
    </div>
    </body>
    </html>

  8. #8
    Membre du Club Avatar de SweetLeaf
    Profil pro
    Inscrit en
    Juillet 2008
    Messages
    151
    Détails du profil
    Informations personnelles :
    Âge : 35
    Localisation : France, Nord (Nord Pas de Calais)

    Informations forums :
    Inscription : Juillet 2008
    Messages : 151
    Points : 55
    Points
    55
    Par défaut
    ah ok ca claque !!
    Merci ! A la prochaine !!

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

Discussions similaires

  1. Cheklistbox, comment tout cocher par un simple click ?
    Par gsmdu62 dans le forum Composants VCL
    Réponses: 7
    Dernier message: 01/05/2006, 10h52
  2. [checkbox] Tout cocher/decocher
    Par thony23 dans le forum Général JavaScript
    Réponses: 8
    Dernier message: 16/11/2005, 11h31
  3. fonction javascript pour tout cocher
    Par Flob dans le forum Général JavaScript
    Réponses: 5
    Dernier message: 17/02/2005, 10h36

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