Maison interface Web tutoriel CSS Comment créer un curseur de plage personnalisé à l'aide de CSS

Comment créer un curseur de plage personnalisé à l'aide de CSS

Feb 09, 2025 pm 12:08 PM

CSS pur crée des curseurs de plage personnalisés cool: pas de javascript requis, les deux accessibilité

Cet article montrera comment créer des curseurs de portée personnalisés en utilisant uniquement des éléments CSS et HTML <input type="range"> natifs sans compter sur JavaScript tout en garantissant l'accessibilité. Les tutoriels couvrent les moyens de personnaliser les éléments d'entrée, y compris la réinitialisation et la désactivation des styles par défaut du navigateur, la définition des styles de curseurs et la création d'effets de gradient de glissement à l'aide de border-image. De plus, il vous expliquera comment ajouter des animations subtiles pour améliorer l'interaction des utilisateurs, telles que la conversion du curseur d'un cercle de bordure uniquement en cercle complet lorsqu'il a cliqué et assombrissant la couleur lorsqu'il est en plané. Cette technologie conserve les fonctionnalités natives et prend en charge la navigation par clavier, offrant une solution polyvalente et facile à accès pour les curseurs de gamme personnalisés.

How to Create a Custom Range Slider Using CSS

Points clés:

  • Créez un curseur de portée personnalisé à l'aide de CSS purs et d'éléments HTML <input type="range"> natifs.
  • Le didacticiel
  • contient des étapes pour personnaliser les éléments d'entrée: réinitialiser et désactiver les styles par défaut du navigateur, définir les styles de curseur et créer des effets de gradient de glissement à l'aide de border-image.
  • Ajoutez des animations subtiles pour améliorer l'expérience utilisateur, telles que la modification de la forme du curseur lors du clic et la modification de la couleur lorsqu'il est en survol.
  • Gardez les fonctionnalités natives et supportez la navigation au clavier pour assurer l'accessibilité.

Le style de curseur de plage par défaut n'est pas beau. La figure suivante montre l'effet d'affichage du curseur de plage par défaut dans les navigateurs Chrome, Firefox et Safari:

How to Create a Custom Range Slider Using CSS

Cependant, les éléments <input type="range"> sont difficiles à coiffer. La plupart des solutions en ligne reposent sur JavaScript et le code verbeux. Pire, certaines technologies peuvent également détruire l'accessibilité des éléments. Voyons donc comment mieux utiliser des CS purs pour réaliser sans affecter l'accessibilité. La démonstration de codep suivante montre ce que nous allons construire: lien de codepen

Structure de l'élément d'entrée de plage

Analysons d'abord la structure de l'élément d'entrée de plage. Il s'agit d'un élément natif et chaque navigateur a sa propre implémentation. Il existe deux implémentations principales: une pour les navigateurs WebKit et Blink (tels que Chrome, Edge, Safari et Opera):

<input type="range" min="0" max="100" step="1" value="20">
Copier après la connexion
Copier après la connexion
Copier après la connexion
Copier après la connexion

How to Create a Custom Range Slider Using CSS

Un autre pour Firefox:

<input type="range" min="0" max="100" step="1" value="20">
Copier après la connexion
Copier après la connexion
Copier après la connexion
Copier après la connexion

How to Create a Custom Range Slider Using CSS

IE a également une troisième implémentation, mais heureusement, ce navigateur a presque disparu maintenant! Cette incohérence entre les navigateurs rend les tâches difficiles car nous devons fournir des styles différents pour chaque implémentation. Je n'entrerai pas dans cela en profondeur car ce post ne sera jamais terminé, mais je recommande fortement de lire ce post par Ana Tudor pour une exploration plus approfondie (les liens de publication doivent être insérés ici). Il vous suffit de vous rappeler que peu importe la mise en œuvre, le "curseur" (pouce) est toujours un composant commun.

How to Create a Custom Range Slider Using CSS

Je stylerai seulement cet élément, ce qui rendra mon curseur de portée personnalisé facile à personnaliser. Sautons directement dans le code et voyons ce qui est incroyable.

Élément d'entrée personnalisé

La première étape consiste à utiliser appearance: none et à certaines autres propriétés communes pour réinitialiser et désactiver tous les styles par défaut du navigateur:

<input type="range" min="0" max="100" step="1" value="20">
Copier après la connexion
Copier après la connexion
Copier après la connexion
Copier après la connexion

Dans les cas plus complexes, si d'autres styles par défaut sont appliqués à nos éléments, nous devrons peut-être ajouter plus de code. Assurez-vous simplement que nous avons un élément "nu" sans aucun style visuel. Définissons également certaines variables CSS afin que nous puissions facilement créer différentes variantes pour le curseur de plage:

<input type="range" min="0" max="100" step="1" value="20">
Copier après la connexion
Copier après la connexion
Copier après la connexion
Copier après la connexion

Dans cette étape, seul le curseur et son style par défaut sont visibles.

Définissez le style de l'élément de curseur

Style, stylissons l'élément de curseur. Nous commencerons par les paramètres de base:

input {
  appearance: none;
  background: none;
  cursor: pointer;
}
Copier après la connexion

Utiliser border-image Ajoutez des effets magiques

Maintenant, nous utiliserons une astuce CSS magique pour compléter notre curseur. Il s'agit de l'utilisation de border-image:

input {
  --c: orange; /* 活动颜色 */
  --g: 8px; /* 间隙 */
  --l: 5px; /* 线粗细 */
  --s: 30px; /* 滑块大小 */

  width: 400px; /* 输入宽度 */
  height: var(--s);
  appearance: none;
  background: none;
  cursor: pointer;
}
Copier après la connexion

L'hallucination est parfaite en ajoutant overflow: hidden à l'élément d'entrée et en utilisant des valeurs plus grandes.

Ajoutez des animations

pouvons-nous ajouter des animations subtiles lors de l'interaction avec le curseur? Il ne nécessite pas beaucoup de code et améliorera l'UX du curseur. Tout d'abord, nous convertissons le curseur d'un cercle de bordure uniquement en cercle complet lorsqu'il a cliqué. Pour ce faire, nous ajoutons la valeur box-shadow de spread.

Conclusion

Nous l'avons fait et n'avons pas à faire face à des implémentations liées au navigateur complexes! Nous avons identifié le sélecteur de l'élément de curseur et utilisé certaines astuces CSS pour styliser toute la gamme des curseurs. N'oubliez pas, nous n'utilisons que l'élément <input type="range">, donc nous n'avons pas à nous soucier des problèmes d'accessibilité car nous gardons les fonctionnalités natives. Le curseur prend en charge la navigation au clavier sans aucun problème. Voici plus d'exemples de curseurs créés avec la même technique: lien de codepen

Codepen Link

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 de ce site Web
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

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Vue 3 Vue 3 Apr 02, 2025 pm 06:32 PM

Il est sorti! Félicitations à l'équipe Vue pour l'avoir fait, je sais que ce fut un effort massif et une longue période à venir. Tous les nouveaux documents aussi.

Pouvez-vous obtenir des valeurs de propriété CSS valides du navigateur? Pouvez-vous obtenir des valeurs de propriété CSS valides du navigateur? Apr 02, 2025 pm 06:17 PM

J'ai eu quelqu'un qui écrivait avec cette question très légitime. Lea vient de bloguer sur la façon dont vous pouvez obtenir les propriétés CSS valides elles-mêmes du navigateur. C'est comme ça.

Cartes empilées avec un positionnement collant et une pincée de sass Cartes empilées avec un positionnement collant et une pincée de sass Apr 03, 2025 am 10:30 AM

L'autre jour, j'ai repéré ce morceau particulièrement charmant sur le site Web de Corey Ginnivan où une collection de cartes se cassent les uns sur les autres pendant que vous faites défiler.

Un peu sur CI / CD Un peu sur CI / CD Apr 02, 2025 pm 06:21 PM

Je dirais que "Site Web" correspond mieux que "Application mobile" mais j'aime ce cadrage de Max Lynch:

Utilisation de Markdown et de la localisation dans l'éditeur de blocs WordPress Utilisation de Markdown et de la localisation dans l'éditeur de blocs WordPress Apr 02, 2025 am 04:27 AM

Si nous devons afficher la documentation à l'utilisateur directement dans l'éditeur WordPress, quelle est la meilleure façon de le faire?

Comparaison des navigateurs pour une conception réactive Comparaison des navigateurs pour une conception réactive Apr 02, 2025 pm 06:25 PM

Il existe un certain nombre de ces applications de bureau où l'objectif montre votre site à différentes dimensions en même temps. Vous pouvez donc, par exemple, écrire

Pourquoi les zones réduites pourpre dans la disposition Flex sont-elles considérées à tort «espace de débordement»? Pourquoi les zones réduites pourpre dans la disposition Flex sont-elles considérées à tort «espace de débordement»? Apr 05, 2025 pm 05:51 PM

Questions sur les zones de slash violet dans les dispositions flexibles Lorsque vous utilisez des dispositions flexibles, vous pouvez rencontrer des phénomènes déroutants, comme dans les outils du développeur (D ...

Comment sélectionner un élément enfant avec l'élément de nom de première classe via CSS? Comment sélectionner un élément enfant avec l'élément de nom de première classe via CSS? Apr 05, 2025 pm 11:24 PM

Lorsque le nombre d'éléments n'est pas fixé, comment sélectionner le premier élément enfant du nom de classe spécifié via CSS. Lors du traitement de la structure HTML, vous rencontrez souvent différents éléments ...

See all articles