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 :

Changer la couleur d'un div


Sujet :

JavaScript

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Mars 2004
    Messages
    24
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2004
    Messages : 24
    Points : 17
    Points
    17
    Par défaut Changer la couleur d'un div
    Bonjour, je commence en programmation et j'aimerais lors d'un click de souris changer la couleur d'un div.

    J'ai 2 div quand on clique sur le premier, je voudrais changer la couleur et lorsqu'on clique sur le deuxième, je voudrais que le premier redevienne sans couleur et le deuxième change de couleur.

    voici mon 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
    <script type="text/javascript" language="JavaScript">
     
    function chgColor (div){
     
     
    document.getElementById(div).style.backgroundColor='#bab9b7';
    var last = div;
    }
     
    </script>
     
    <div id="div1"> <a href="#" onclick="chgColor('div1');"> clique 1 </a></div>
     
    <div id="div2"> <a href="#" onclick="chgColor('div2');"> clique 2 </a></div>

  2. #2
    Membre chevronné

    Homme Profil pro
    Ingénieur Hospitalier
    Inscrit en
    Juillet 2004
    Messages
    993
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur Hospitalier
    Secteur : Santé

    Informations forums :
    Inscription : Juillet 2004
    Messages : 993
    Points : 1 768
    Points
    1 768
    Billets dans le blog
    1
    Par défaut
    Salut peut être un bon petit mélange, de hover et te montrer aussi un peu la puissance de css pour le coup dans ton cas de figure:
    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 type="text/javascript">
     
    </script>
    <style type="text/css">
    div[id*=div]:hover{
    	width:100%;
    	background-color: #bab9b7;
    	cursor:pointer;
    }
    </style>
    </head>
    <body>
    <script type="text/javascript" language="JavaScript">
     
    function chgColor (div){
     
    	var objDiv = document.getElementsByClassName("fictif");
    	div.style.backgroundColor="#bab9b7";
    	for(i in objDiv){
    		if(div.id != objDiv[i].id){
    			objDiv[i].style.backgroundColor="";
    		}
    	}
    };
     
    </script>
     
    <div class="fictif" id="div1" onclick="chgColor(this);"> <a href="#"> clique 1 </a></div>
    <div class="fictif" id="div2" onclick="chgColor(this);"> <a href="#" > clique 2 </a></div>
    </body>
    </html>
    Si la réponse te convient, un résolu serait sympathique merci , bonne soirée.

  3. #3
    Expert éminent sénior
    Avatar de Auteur
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    7 650
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 7 650
    Points : 11 142
    Points
    11 142
    Par défaut
    bonsoir,

    En plus de la solution CSS donnée précédemment, voici deux solutions javascript :

    1. 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
      var lastDiv = null;
      function chgColor(currentDiv)
      {
      	document.getElementById(currentDiv).style.backgroundColor='#bab9b7';
      	if (lastDiv!=null)
      	{
      		document.getElementById(lastDiv).style.backgroundColor='transparent';
      	}
       
      	lastDiv = currentDiv;
      }
      </script> 
       
       
      <div id="div1" onclick="chgColor('div1');"> clic 1 </div>
      <div id="div2" onclick="chgColor('div2');"> clic 2 </div>

    2. 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
      <script type="text/javascript">
      var lastDiv = null;
      function chgColor(currentDiv)
      {
      	currentDiv.style.backgroundColor='#bab9b7';
      	if (lastDiv!=null)
      	{
      		lastDiv.style.backgroundColor='transparent';
      	}
       
      	lastDiv = currentDiv;
      }
      </script> 
      <div id="div1" onclick="chgColor(this);"> clic 1 </div>
      <div id="div2" onclick="chgColor(this);"> clic 2 </div>


    Deux remarques également :
    - définis toujours tes variables, même les variables globales ;
    - ne donne jamais à une variable le nom d'une balise, d'un identifiant (id), d'un nom (name) ou d'un mot-clef JS.

  4. #4
    Membre à l'essai
    Profil pro
    Inscrit en
    Mars 2004
    Messages
    24
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2004
    Messages : 24
    Points : 17
    Points
    17
    Par défaut
    j'ai prit la solution en javascript car elle est plus compatible avec tout les navigateurs, merci à vous 2 pour votre aide, c'est très apprécié.

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

Discussions similaires

  1. Réponses: 30
    Dernier message: 12/07/2013, 19h41
  2. Changer de couleur une div dans lequel il y a un tableau
    Par leara500 dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 01/03/2013, 15h29
  3. [VB6]Changer la couleur d'une ligne d'un ListView
    Par Troopers dans le forum VB 6 et antérieur
    Réponses: 3
    Dernier message: 14/03/2003, 17h02
  4. Changer la couleur de fond de l'écran
    Par tnk dans le forum x86 16-bits
    Réponses: 5
    Dernier message: 19/01/2003, 01h37
  5. Changer les couleurs de la palette avec du RGB
    Par le mage tophinus dans le forum x86 16-bits
    Réponses: 11
    Dernier message: 13/01/2003, 08h55

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