Maison  >  Article  >  interface Web  >  Comment obtenir des changements persistants de style de bouton lors d’un clic ?

Comment obtenir des changements persistants de style de bouton lors d’un clic ?

DDD
DDDoriginal
2024-10-31 00:42:29770parcourir

How to Achieve Persistent Button Style Changes on Click?

Sélecteur de bouton enfoncé

Problème :

Vous rencontrez un scénario dans lequel vous désirez modifier l'apparition d'un bouton lorsqu'il est enfoncé pour créer un retour visuel perceptible. Vous avez tenté d'utiliser la pseudo-classe :active, mais le changement de style ne se produit que lorsque vous cliquez et maintenez le bouton enfoncé.

Réponse :

Pendant que :active la pseudo-classe peut sembler une option appropriée, elle est spécifiquement conçue pour styliser un élément pendant qu'il est activement enfoncé. Pour obtenir l'effet souhaité, une approche alternative est recommandée.

Envisagez d'utiliser un élément d'ancrage au lieu d'un élément. Cela ne correspond peut-être pas précisément à votre besoin initial, mais cela ouvre des possibilités supplémentaires si vous ne parvenez pas à trouver une solution directe en utilisant  :

Code CSS :

<code class="css">a {
  display: block;
  font-size: 18px;
  border: 2px solid gray;
  border-radius: 100px;
  width: 100px;
  height: 100px;
  text-align: center;
  line-height: 100px;
}

a:active {
  font-size: 18px;
  border: 2px solid green;
  border-radius: 100px;
  width: 100px;
  height: 100px;
}

a:target {
  font-size: 18px;
  border: 2px solid red;
  border-radius: 100px;
  width: 100px;
  height: 100px;
}</code>

Code HTML :

<code class="html"><a id="btn" href="#btn">Demo</a></code>

Avec cette approche, vous pouvez désormais observer le comportement suivant :

  • État normal : le bouton est blanc
  • Lorsque vous cliquez : le bouton devient vert
  • Après avoir été relâché : le bouton devient rouge

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn