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 :

Sorte de fonction ClickOut()


Sujet :

jQuery

  1. #1
    Membre du Club
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mai 2004
    Messages
    68
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Mai 2004
    Messages : 68
    Points : 56
    Points
    56
    Par défaut Sorte de fonction ClickOut()
    Bonjour,

    J'ai dans mon code la situation suivante :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    <a onclick="displayZone();" id="link-zone">Afficher Zone</a>
    <div id="zone" style="display: none;">
    BLA BLA BLA BLA
    </div>
    Pour gérer l'affichage de ma zone, j'ai un .js avec :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    $(function() {
    	$('#link-zone').click(
    		function(event){
    			$('#zone').show();
    		}
    	);
    });
    Jusque là tout fonctionne très bien, quand je clique sur mon lien, ma zone s'affiche.

    Ma requête : j'aimerais qu'une fois ma zone affichée, elle disparaisse lorsque je clique HORS de cette zone.

    Comment faire ? Des idées ? Des pistes ?

    Merci par avance !

  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 et presque bonjour (2 h 30 !)

    Voici un exemple avec trois possibilités :
    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
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
     
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="fr">
    <head>
    	<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    	<meta name="Author" content="Daniel Hagnoul" />
    	<title>Page type</title>
    	<style type="text/css">
    		body {
    			background-color:#696969;
    			color:#000000;
    			font-family:Arial, Helvetica, sans-serif;
    			font-size:medium;
    			font-style:normal;
    			font-weight:normal;
    			line-height:normal;
    			letter-spacing:normal;
    		}
    		h1,h2,h3,h4,h5 {
    			font-family:"Times New Roman", Times, serif;
    		}
    		div,p,h1,h2,h3,h4,h5,h6,ul,ol,dl,form,table,img {
    			margin:0px;
    			padding:0px;
    		}
    		p {
    			padding:6px;
    		}
    		ul,ol,dl {
    			list-style:none;
    			padding-left:6px;
    			padding-top:6px;
    		}
    		li {
    			padding-bottom:6px;
    		}
    		div#conteneur {
    			width:95%;
    			margin:12px auto;
    			padding:6px;
    			background-color:#FFFFFF;
    			color:#000000;
    			border:1px solid #666666;
    			font-size:0.8em;
    		}
     
    		/* TEST */
     
    		.zone {
    			width:100px;
    			height:100px;
    			margin:12px;
    			background-color:#CCCCCC;
    			border:1px solid #666666;
    		}
    		.zone a {
    			display:block;
    			width:auto;
    			height:20px;
    			padding:3px;
    			text-align:center;
    			background-color:#0033FF;
    			color:#FFFFFF;
    			font-size:1em;
    			border:1px solid #000099;
    		}
    	</style>
    	<script type="text/javascript" src="../lib/jquery-1.3.2.min.js"></script>
    	<script type="text/javascript">
    		$(document).ready(function(){
    			var boolZone3 = false;
     
    			$('#link-zone1').click(function(){
    				$('#zone1').toggle();
    				return false;
    			});
     
    			$('#link-zone2').hover(
    				function(){
    					$('#zone2').show();
    				},
    				function(){
    					$('#zone2').hide();
    				}
    			);
     
    			$('#link-zone3').click(function(){
    				if (!boolZone3) {
    					$('#zone3').show();
    					boolZone3 = true;
    				}
     
    				return false;
    			});
     
    			$("#conteneur").click(function(){
    				if (boolZone3){
    					$('#zone3').hide();
    					boolZone3 = false;
    				}
     
    				return false;
    			});
     
    		});
    	</script>
    </head>
    <body>
    	<div id="conteneur">
     
    		<div class="zone">
    			<a id="link-zone1">Afficher Zone1</a>
    			<div id="zone1" style="display: none;">
    				BLA BLA BLA BLA
    			</div>
    		</div>
     
    		<div class="zone">
    			<a id="link-zone2">Afficher Zone2</a>
    			<div id="zone2" style="display: none;">
    				BLA BLA BLA BLA
    			</div>
    		</div>
     
    		<div class="zone">
    			<a id="link-zone3">Afficher Zone3</a>
    			<div id="zone3" style="display: none;">
    				BLA BLA BLA BLA
    			</div>
    		</div>
     
    	</div>
    </body>
    </html>

    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
    Membre du Club
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mai 2004
    Messages
    68
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Mai 2004
    Messages : 68
    Points : 56
    Points
    56
    Par défaut
    Super ! Le dernier exemple me va parfaitement !

    Merci beaucoup pour ce coup de pouce !

  4. #4
    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.

    Petite correction :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    $("#conteneur").click(function(){
        if (boolZone3){
            $('#zone3').hide();
            boolZone3 = false;
        }
    });
    Pas de return false ! Il n'y a, ici, aucune raison de bloquer la propagation des événements « click » à ce niveau du DOM.

    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.)

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

Discussions similaires

  1. Paramètrer la fonction sort()...
    Par Empty_body dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 12/06/2007, 12h28
  2. [STL]vector de type composé et fonction sort
    Par LordBob dans le forum SL & STL
    Réponses: 14
    Dernier message: 21/03/2007, 11h56
  3. [VBA-E]Fonction "Sort" et format
    Par Capsule dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 12/01/2007, 14h29
  4. Probleme fonction sort d'unt list STL
    Par Brouzouf dans le forum Visual C++
    Réponses: 4
    Dernier message: 27/07/2006, 16h54
  5. help fonction tri bubble sort
    Par Invité dans le forum C
    Réponses: 10
    Dernier message: 22/12/2005, 20h54

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