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 :

détecter un click à l'extérieur d'une division


Sujet :

jQuery

  1. #1
    Nouveau membre du Club
    Inscrit en
    Avril 2009
    Messages
    48
    Détails du profil
    Informations forums :
    Inscription : Avril 2009
    Messages : 48
    Points : 38
    Points
    38
    Par défaut détecter un click à l'extérieur d'une division
    Hi,

    j'ai fais un pti code jquery pour afficher une liste de checkbox. Ca fonctionne bien mais j'aimerais détecter un clique à l'extérieur de la div pour faire disparaitre la div. Pour le moment il faut recliquer sur afficher :/

    Si quelqu'un a une idé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
    <html> 
    <head> 
    <script language="javascript" src="jquery.js"></script> 
    <style>
        #container {
            margin-top:30px;
        }
        #chxkDiv {
            background-color:white;
            border:solid 1px black;
            position:absolute;
        }
    </style>
    <script> 
    $(document).ready(function() {
        $("#chxkDiv").css("display","none");
        $("#linkSelect").click(function() {
            if($("#chxkDiv").css("display")=='none')
            $("#chxkDiv").css("display","block");
            else
            $("#chxkDiv").css("display","none");
        });
     });
    </script>
    </head> 
    <body>
        <div id="container">
        <p id="linkSelect">afficher</p>
        <div id="chxkDiv">
            <input type="checkbox" name="ckx_1" id="ckx_1" /><label for="ckx_1" >Choix 1</label><br />
        </div>
        </div>
    </body> 
    </html>

  2. #2
    Rédacteur

    Avatar de danielhagnoul
    Homme Profil pro
    Étudiant perpétuel
    Inscrit en
    Février 2009
    Messages
    6 389
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 73
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant perpétuel
    Secteur : Enseignement

    Informations forums :
    Inscription : Février 2009
    Messages : 6 389
    Points : 22 933
    Points
    22 933
    Billets dans le blog
    125
    Par défaut
    Bonsoir.

    Je vous conseille de regarder ce post : http://www.developpez.net/forums/d84...l/#post4823788

    Si cette réponse ne vous aide pas, n'hésitez pas à le faire savoir.

    Blog

    Sans l'analyse et la conception, la programmation est l'art d'ajouter des bogues à un fichier texte vide.
    (Louis Srygley : Without requirements or design, programming is the art of adding bugs to an empty text file.)

  3. #3
    Nouveau membre du Club
    Inscrit en
    Avril 2009
    Messages
    48
    Détails du profil
    Informations forums :
    Inscription : Avril 2009
    Messages : 48
    Points : 38
    Points
    38
    Par défaut
    J'ai pas compris pourquoi tu n'utilise pas les events de jquery ?

    J'ai finalement trouvé la réponse à ma question ici : http://stackoverflow.com/questions/1...ide-an-element

    Et voila le code final :
    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
    <html> 
    <head> 
    <script language="javascript" src="jquery.js"></script> 
    <style>
    	#container {
    		margin-top:30px;
    	}
    	#chxkDiv {
    		background-color:white;
    		border:solid 1px black;
    		position:absolute;
    	}
     
    </style>
    <script> 
    $(document).ready(function() {
    	$('html').click(function() {
    		$("#chxkDiv").css("display","none");
    	});
     
    	$('#chxkDiv').click(function(event){
    		event.stopPropagation();
    	});
    	$("#chxkDiv").css("display","none");
    	$("#linkSelect").click(function(event) {
    		event.stopPropagation();
    		if($("#chxkDiv").css("display")=='none')
    			$("#chxkDiv").css("display","block");
    		else
    			$("#chxkDiv").css("display","none");
    	});
     });
    </script>
    </head> 
    <body>
    	<div id="container">
    	<p id="linkSelect">afficher</p>
    	<div id="chxkDiv">
    		<input type="checkbox" name="ckx_1" id="ckx_1" /><label for="ckx_1" >Choix 1</label><br />
    	</div>
    	</div>
    </body> 
    </html>
    Si c'est cliqué sur le document ça ferme tout, mais si c'est cliqué sur une div l'évenement est arrêté donc la div reste. C'est vraiment puissant jquery

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

Discussions similaires

  1. Détecter le click sur une "class"
    Par jd440 dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 20/08/2013, 11h32
  2. Détecter le click sur une bannière de pub
    Par jaljal dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 12/07/2010, 17h28
  3. Réponses: 1
    Dernier message: 19/02/2010, 18h41
  4. Détecter le click sur une combobox d'une datagridview
    Par Delphi-ne dans le forum Windows Forms
    Réponses: 11
    Dernier message: 21/04/2009, 11h22
  5. détecter un clic à l'extérieure d'une div
    Par Overstone dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 31/08/2007, 18h40

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