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 :

JQuery: évènement sur checkbox


Sujet :

jQuery

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    45
    Détails du profil
    Informations personnelles :
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Juin 2006
    Messages : 45
    Points : 13
    Points
    13
    Par défaut JQuery: évènement sur checkbox
    Bonjour,

    dans un label (avec un id généré par PHP) se trouve une checkbox,

    comportement souhaité: quand je sélectionne la checkbox (directement ou sur le label) > le background du label change et quand je désélectionne > le background revient à la normale.

    J'ai un peu honte de poster ça mais après de nombreux essais je reste toujours bloqué, j'utilisais la fonction toggle de jquery et onclick sur le label mais le comportement n'est jamais bon. j'ai essayé onfocus, onselect, onchange : à chaque fois un comportement bizard et différent




    merci

  2. #2
    Membre à l'essai
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    45
    Détails du profil
    Informations personnelles :
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Juin 2006
    Messages : 45
    Points : 13
    Points
    13
    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
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    <!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=iso-8859-1" />
    <title>Untitled Document</title>
    <script type="text/javascript" src="jquery/jquery.js"></script>
    <script type="text/javascript" src="jquery/jquery.cookie.js"></script>
    <script type="text/javascript" language="javascript">
     
    	function toggle_bg(checkb, label){
    	$(checkb).toggle(
    		function(){ $(label).css('background', '#FF942B'); }, 
    		function(){ $(label).css('background', '#33FF00');} 
    		)
    }
     
    </script>
    <style type="text/css" >
    label{
    background:#33FF00;
    }
    </style>
    </head>
     
    <body>
    <form>
    <label id="d" style=" display:block; width: 100px; height: 100px;">
    <input type="checkbox" onclick="toggle_bg('#d input', '#d');" name="gogo"/>
    </label>
     
    </form>
    </body>
    </html>

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    92
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2004
    Messages : 92
    Points : 80
    Points
    80
    Par défaut
    La solution porte sur l'évenement onchange.

    Tu initialises le javascript comme 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
     
    //Au chargement de la page
    $(document).ready(function(){
            //on récupère le label
    	var label = $("#d");
            //sur le onchange de la checkbox
    	$("[name=gogo]").change(function(){
                    //si la case a cocher est cochée
    		if(this.checked){
    			$(label).css('background', '#FF942B');
    		}else{
    			$(label).css('background', '#33FF00');
    		} 
    	});
    });
    N'oublie pas d'enlever le onclick sur la checkbox

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    <input type="checkbox" name="gogo"/>
    voila.

  4. #4
    Membre à l'essai
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    45
    Détails du profil
    Informations personnelles :
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Juin 2006
    Messages : 45
    Points : 13
    Points
    13
    Par défaut
    Merci beaucoup, mais hélas ça ne fonctionne pas

    Deplus dans mon cas réel, il y a plusieurs centaines de checkboxes avec chacune une id générée par php, donc je ne crois pas que la méthode de récupération d'id que tu me proposes soit adaptée

    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=iso-8859-1" />
    <title>Untitled Document</title>
    <script language="javascript" type="text/javascript">
    //Au chargement de la page
    $(document).ready(function(){
            //on récupère le label
    	var label = $("#d");
            //sur le onchange de la checkbox
    	$("[name=gogo]").change(function(){
                    //si la case a cocher est cochée
    		if(this.checked){
    			$(label).css('background', '#FF942B');
    		}else{
    			$(label).css('background', '#33FF00');
    		} 
    	});
    });
    </script>
    <style type="text/css" >
    label{
    background:#33FF00;
    }
    </style>
    </head>
     
    <body>
    <form>
    <label id="d" style=" display:block; width: 100px; height: 100px;">
    <input type="checkbox" name="gogo"/>
    </label>
     
    </form>
     
    </body>
    </html>

  5. #5
    Membre à l'essai
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    45
    Détails du profil
    Informations personnelles :
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Juin 2006
    Messages : 45
    Points : 13
    Points
    13
    Par défaut
    Bon, j'ai bidouillé un peu ton code et ça fonctionne bien
    Merci pour ton aide

    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
    <!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=iso-8859-1" />
    <title>Untitled Document</title>
    <script type="text/javascript" src="jquery/jquery.js"></script>
    <script type="text/javascript" src="jquery/jquery.cookie.js"></script>
    <script language="javascript" type="text/javascript">
    	function toggle_bg(id){
            //on récupère le label
    		var label = $("#"+id+"_label");
    		//sur le onchange de la checkbox
    		$("#"+id).change(
    			function(){
    						//si la case a cocher est cochée
    				if(this.checked){
    					$(label).css('background', '#FF942B');
    				}else{
    					$(label).css('background', '#33FF00');
    				} 
    			}
    		);
    	}
    </script>
    <style type="text/css" >
    label{
    background:#33FF00;
    }
    </style>
    </head>
     
    <body>
    <form>
    <table>
    <tr>
    <td onclick="toggle_bg('23-06')">
    <label id="23-06_label" style=" display:block; width: 100px; height: 100px;" >
    <input type="checkbox" name="gogo[]" id="23-06" />
    </label>
    </td>
    <td onclick="toggle_bg('24-06')">
    <label id="24-06_label" style=" display:block; width: 100px; height: 100px;" >
    <input type="checkbox" name="gogo[]" id="24-06" />
    </label>
    </td>
    </tr>
    </table>
     
    </form>
     
    </body>
    </html>

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

Discussions similaires

  1. [XL-2010] Gestion d'évènements sur Checkbox Dynamique
    Par pinhut dans le forum Macros et VBA Excel
    Réponses: 7
    Dernier message: 16/06/2015, 17h52
  2. Réponses: 13
    Dernier message: 30/05/2012, 10h42
  3. [JQuery] 1 seul événements sur 2 (au choix)
    Par popovitch130 dans le forum jQuery
    Réponses: 4
    Dernier message: 25/11/2008, 22h34
  4. jquery et valeur checked sur checkbox
    Par fullqwerty dans le forum jQuery
    Réponses: 13
    Dernier message: 06/11/2008, 01h04
  5. Problèmes d'évènements sur ComboBox
    Par bakaneko dans le forum MFC
    Réponses: 3
    Dernier message: 23/02/2004, 08h46

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