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 :

Filtrer une liste des cases à cocher


Sujet :

JavaScript

  1. #1
    Invité
    Invité(e)
    Par défaut Filtrer une liste des cases à cocher
    Bonjour,

    Est ce que vous pourriez me dire comment faire pour résoudre ce problème? j'essaie de filtrer la liste des éléments mais rien ne change, par exemple, en tapant "afg" la liste des pays doit se réduire à Afghanistan mais tous les pays s'affichent toujours sur la liste. Je crois que le problème se situe dans la fonction ListeCheck() mais je n'arrive pas à le trouver.

    Merci d'avance

    Voici le code:

    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
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
     
    <html><head>
    <style type="text/css">
    	.container { border:2px solid #ccc; width:300px; height: 150px; overflow-y: scroll; }	
    	.tete { width:300px;}
    </style>
     
    <script type="text/javascript">
     
    var Liste=new CreerListe("Pays")
    Liste.Add("Afghanistan");
    Liste.Add("Afrique du sud");
    Liste.Add("Albanie");
    Liste.Add("Chili");
    Liste.Add("Finlande");
    Liste.Add("France");
    Liste.Add("Gabon");
    Liste.Add("Gambie");
    Liste.Add("Honduras");
    Liste.Add("Irlande");
    Liste.Add("Islande")
    Liste.Add("Italie");
    Liste.Add("Japon");
    Liste.Add("Jordanie");
    Liste.Add("Lettonie");
    Liste.Add("Liban");
    Liste.Add("Malte");
    Liste.Add("Maroc");
    Liste.Add("Namibie");
     
    function CreerListe(nom) {
    	this.nom=nom;
    	this.search="";
    	this.nb=0; 
    	this.Add=AjouterItem;
    	this.Afficher=AfficherListe;
    	this.MAJ=MAJListe;
    }
     
    function AjouterItem(item) {
    	this[this.nb]=item
    	this.nb++;
    }
     
    function AfficherListe() {
    	var Z="<SPAN name="+this.nom+"><div class=\"container\">";
    	for (var i=0; i<this.nb; i++) {
    		Z+="<input type=\"checkbox\" value=\""+this[i]+"\" />"+this[i]+"<br/>";	
    	}
    	Z+="</span></div>"
    	document.write(Z);
    }
     
    function MAJListe(txt,f) {
    	if (txt!=this.search) {
    		this.search=txt;
    		f.elements[this.nom].options.length=0; 
    		for (var i=0; i<this.nb; i++) {
    			if ( this[i].substring(0,txt.length).toUpperCase()==txt.toUpperCase() ) {
    				var o=new Option(this[i], this[i]);
    				f.elements[this.nom].options[f.elements[this.nom].options.length]=o;
    			}
    		}
    		if (f.elements[this.nom].options.length==1) {
    			f.elements[this.nom].selectedIndex=0;
    		}
    	}
    }
     
    function ListeCheck() {
    	Liste.MAJ(document.forms["monform"].search.value,document.forms["monform"].getElementsByName["input"])
    	if (document.layers) {
    		setTimeout("ListeCheck()", 1001)
    	} else {
    		setTimeout("ListeCheck()", 100)
    	}
    }
    </script>
    </head>
     
    <div>
    	<input type="text" class="tete" onclick="javascript:hideshow(document.getElementById('tete1'))"/>
    </div>
    <div id="tete1" classe="psiu">
    <form name="monform">
    	<input type="text" class="tete" name="search" /> <br />
            <script type="text/javascript">
    	      Liste.Afficher();
    	      ListeCheck();
            </script>
            <div>
            <input type="button" value="Ajouter" />
            </div>
    </form>
    </div>
    <script type="text/javascript">
             function hideshow(which){
                    if (!document.getElementById)
                    return
                    if (which.style.display=="none")
                    which.style.display="block"
                    else
                    which.style.display="none"
             };
     
    hideshow(document.getElementById('tete1'));
    </script>
    </body>
    </html>

  2. #2
    Membre expérimenté
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2003
    Messages
    1 305
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2003
    Messages : 1 305
    Points : 1 383
    Points
    1 383
    Par défaut
    Bonjour,

    avez-vous vérifié les paramètres envoyés à la fonction MAJ (en les affichant dans la console (console.log) par exemple) ?

    Il n'y a pas d'élément s'appelant "input" alors qu'il est passé en paramètre de MAJ (document.forms["monform"].getElementsByName["input"]), et s'il y en avait un ce serait une mauvaise idée.
    Pour les paramètres lors de l'appel de MAJ, pourquoi n'utilisez-vous pas document.getElementById ?

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

    Merci pour votre réponse, en fait le probleme était dans la fonction MAJ comme vous avez dit, je l'ai modifié et ça marché
    Dernière modification par NoSmoking ; 03/05/2016 à 13h41. Motif: Inutile de citer un message pour y répondre, il existe un bouton répondre à la discussion.

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

Discussions similaires

  1. [MySQL] Réalisation d'une liste avec case à cocher
    Par Lunedora87 dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 29/04/2009, 11h47
  2. liste des case à cocher
    Par l.fafo dans le forum VB.NET
    Réponses: 8
    Dernier message: 27/04/2009, 18h13
  3. liste des case à cocher
    Par l.fafo dans le forum Général JavaScript
    Réponses: 5
    Dernier message: 24/04/2009, 16h21
  4. Récupérer valeurs d'une liste de cases à cocher
    Par jminguely dans le forum Langage
    Réponses: 3
    Dernier message: 10/10/2008, 22h10
  5. Cocher des cases d'une liste de cases à cocher
    Par isachat666 dans le forum Composants VCL
    Réponses: 2
    Dernier message: 05/12/2005, 13h17

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