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 :

Checkboxes JSF/Javascript check/unckeck trop lent


Sujet :

JavaScript

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Novembre 2008
    Messages
    226
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : Suisse

    Informations forums :
    Inscription : Novembre 2008
    Messages : 226
    Par défaut Checkboxes JSF/Javascript check/unckeck trop lent
    Bonjour,

    j'ai une page jsf contenant des checkboxes. J'ai une checkbox "principale" qui permet de sélectionner/désélectionner toutes les autres. Mais j'ai un petit souci de vitesse. Il faut 2 secondes pour que toutes les 50 checkboxes soient cochées...rien de grave, mais ce n'est pas très propre...

    J'aimerais savoir s'il y a d'autres possibilités pour faire la même chose, mais bien plus performantes..

    Voilà mon code:

    Fonction Javascript:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    function selectUnselectAllFields(checkbox)
    {
    	var elements = document.forms.tSearch.elements;
    	for (var i = 0; i < elements.length; i++)
    	{
    		var el = elements[i];
    		if (el.name != null && /^tSearch:cb\d*/.test(el.name))			
    		{
    			el.checked = checkbox.checked;
    		}
    	}
    }
    JSF:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    <h:panelGrid columns="2" columnClasses="formInputSmallFont, formInputSmallFont">
    	<f:verbatim>
    		<input type="checkbox" onclick="selectUnselectAllFields(this)"></input>
    	</f:verbatim>
    	<h:outputText value="Select All"/>
    </h:panelGrid>
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    <h:panelGrid columns="12" columnClasses="formInputSmallFont,formInputSmallFont,formInputSmallFont,formInputSmallFont,formInputSmallFont,formInputSmallFont,formInputSmallFont,formInputSmallFont,formInputSmallFont,formInputSmallFont,formInputSmallFont,formInputSmallFont">
    	<h:selectBooleanCheckbox id="cbTID" value="#{terminalManager.cbTID}"/>
    	<h:outputText value="TID" />
    	<h:selectBooleanCheckbox id="cbMID" value="#{terminalManager.cbMID}"/>
    	<h:outputText value="MID" />
     
    .....autres 48 Checkbox.....
    </h:panelGrid>

  2. #2
    Rédacteur/Modérateur

    Avatar de SpaceFrog
    Homme Profil pro
    Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Inscrit en
    Mars 2002
    Messages
    39 659
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2002
    Messages : 39 659
    Billets dans le blog
    1
    Par défaut
    faire la regexp à l'intérieur de la boucle ... tu m'etonnes que ce soit lent ...
    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
     
    <script type="text/javascript">
     
    document.getElementsByReg=function(reg,attr){
    var tabReg=new Array();
    var tabElts=document.body.getElementsByTagName('*');
    var TEL=tabElts.length;
    if(! (reg instanceof RegExp)){return tabReg;}
    i=0;
    while(tabElts[i]){
    		if(tabElts[i][attr]){
     
    	         if(reg.test(tabElts[i][attr])){tabReg.push(tabElts[i]);}
    	         }
    	i++;         
    	}
    return tabReg;
    }
     
    function selectUnselectAllFields(checkbox)
    {
    	var elements = document.forms.getElementsByReg(/^tSearch:cb\d*/s,name);
    var i=-1;
    while(elements[++i])
    	{
    			elements[i].checked=true;
    		}
    	}
    }
    Ma page Developpez - Mon Blog Developpez
    Président du CCMPTP (Comité Contre le Mot "Problème" dans les Titres de Posts)
    Deux règles du succès: 1) Ne communiquez jamais à quelqu'un tout votre savoir...
    Votre post est résolu ? Alors n'oubliez pas le Tag

    Venez sur le Chat de Développez !

  3. #3
    Expert confirmé
    Avatar de javatwister
    Homme Profil pro
    danseur
    Inscrit en
    Août 2003
    Messages
    3 684
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Calvados (Basse Normandie)

    Informations professionnelles :
    Activité : danseur

    Informations forums :
    Inscription : Août 2003
    Messages : 3 684

  4. #4
    Membre éclairé
    Profil pro
    Inscrit en
    Novembre 2008
    Messages
    226
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : Suisse

    Informations forums :
    Inscription : Novembre 2008
    Messages : 226
    Par défaut
    Merci!!

    J'ai juste adapté un peut le code de SpaceFrog, je ne comprend pas trop d'où prendre "name" dans "selectUnselectAllFields" et comment fonctionne "[attr]" dans "document.getElementsByReg=function(reg,attr)". Mais je crois de n'en avoir pas besoin, car je compare tous les elements avec mon reg...

    Ensuite j'ai juste crée une nouvelle fonctions, j'avais un erreur avec la formule "document.getElementsByReg=function(reg,attr){", la fonction n'était pas trouvée...

    Mais comme ça, chez moi ça fonctionne ni quel, c'est pratiquement instantané:

    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
    function selectUnselectCheckBox(reg)
    {	
    	var tabReg=new Array();
    	var tabElts=document.body.getElementsByTagName('*');
     
    	if(! (reg instanceof RegExp)){return tabReg;}
    	i=0;
    	while(tabElts[i]){
    		if(reg.test(tabElts[i].name)){tabReg.push(tabElts[i]);}  
    		i++;         
    	}
    	return tabReg;
    }
     
    function selectUnselectAllFields(checkbox)
    { 
    	var elements = selectUnselectCheckBox(/^tSearch:cb\d*/);
    	var i=-1;
    	while(elements[++i])
    	{
    		elements[i].checked=checkbox.checked;
    	}
    }

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

Discussions similaires

  1. Chargement trop lent de photos dans diaporama javascript !
    Par Gigibigi dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 08/11/2013, 17h04
  2. Javascript JqueryUI trop lent - une solution ?
    Par tchoumak dans le forum jQuery
    Réponses: 2
    Dernier message: 02/10/2009, 20h09
  3. boucle while trop lente
    Par atouze dans le forum Access
    Réponses: 17
    Dernier message: 15/06/2005, 16h35
  4. [SAGE] ODBC trop lent
    Par tileffeleauzed dans le forum Décisions SGBD
    Réponses: 1
    Dernier message: 14/11/2004, 09h56
  5. Envoi de mail trop lent
    Par MASSAKA dans le forum ASP
    Réponses: 3
    Dernier message: 15/10/2004, 10h57

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