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

Contribuez Discussion :

[FAQ] Comment modifier le style d'une balise au survol sans JavaScript ?


Sujet :

Contribuez

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Rédacteur
    Avatar de bigboomshakala
    Homme Profil pro
    Consultant Web .NET
    Inscrit en
    Avril 2004
    Messages
    2 077
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Consultant Web .NET
    Secteur : Finance

    Informations forums :
    Inscription : Avril 2004
    Messages : 2 077
    Par défaut [FAQ] Comment modifier le style d'une balise au survol sans JavaScript ?
    [QR] Comment modifier le style d'une balise au survol sans JavaScript ?

    Avec les navigateurs récents il est possible d'utiliser la pseudo-classe :hover pour agir sur les balises au moment de leur survol. On peut par exemple définir les styles img{ width:100px; } et img:hover { width:auto; } pour qu'au survol d'une image celle-ci prenne sa taille réelle.

    Malheureusement Internet Explorer 6 (navigateur encore très largement utilisé de nos jours) ne comprend la pseudo-classe :hover que sur les liens...

    L'idée est alors d'encapsuler dans un lien la balise sur laquelle on veut agir :
    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
    <html>
        <head>
            <style>
    a img
    {
        width:100px;
        border:0px;
    }
     
    a:hover img
    {
        width:auto;
        border:0px;
    }    
     
    a:hover input
    {
        background-color : red;
    }       
            </style>
        </head>
        <body>
            <a href="javascript:void 0;">
                <img src="uneImage.jpg" />
            </a>
     
            <a href="javascript:void 0;">
                <input type=text value="salut mon pote"/>plop
            </a>
        </body>
    </html>
    Là vous vous dites "génial, au final moyennant une petite astuce on peut faire la même chose sur IE6 !". Et bien non, cela ne fonctionne pas. un style a:hover est correctement interprété, mais a:hover uneBalise n'est pas reconnu.

    Cependant IE6 est capable de comprendre ces pseudo-classe s'ils définissent une valeur pour la propriété filter (allez savoir pourquoi?!?), là ça fonctionne !!!
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    a:hover img
    {
        filter:alpha(opacity=100);
        width:auto;
        border:0px;
    }   
     
    a:hover input
    {
        filter:alpha(opacity=100);
        background-color : red;
    }
    Voilà comment, sans JavaScript, vous pouvez modifier le style d'une balise au survol de cette dernière, et cela de manière totalement compatible sur tous les navigateurs modernes

  2. #2
    Expert confirmé
    Avatar de Auteur
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    7 660
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 7 660
    Par défaut
    juste une précision :
    une balise <a> (type inline) ne peut contenir que des balises inline (img, span, input) sauf une autre balise <a>. Donc il est hors de question d'écrire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
            <a href="javascript:void 0;">
                <div> salut tout le monde <br/>
                </div> 
            </a>
    car le div est une balise de type block, tout comme les balises <p>, <form>, etc. de même, ne pas encadrer d'une balise <a> des balises pour le tableau : <table>, <td>, <tr>, <th>, <tbody>....

Discussions similaires

  1. Comment modifier le style d'une InfoWindow ?
    Par deuxk dans le forum APIs Google
    Réponses: 1
    Dernier message: 13/05/2012, 16h22
  2. [XSL] Comment modifier la valeur d'une variable?
    Par sorcer1 dans le forum XSL/XSLT/XPATH
    Réponses: 8
    Dernier message: 17/02/2010, 13h26
  3. Réponses: 1
    Dernier message: 24/11/2008, 14h38
  4. [TRichEdit] Comment modifier le style d'une sélection ?
    Par PpPool dans le forum Composants VCL
    Réponses: 2
    Dernier message: 15/11/2005, 10h16
  5. comment modifier les données d'une table à travers un dbgrid
    Par bertrand_declerck dans le forum Bases de données
    Réponses: 12
    Dernier message: 19/07/2005, 09h51

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