Table des matières
1. Déclaration des variables
2. La fonction var()
3. Type de valeur de variable
4. Portée
5. Mise en page responsive
6. Traitement de compatibilité
7. Opération JavaScript
Maison interface Web tutoriel CSS Introduction à l'utilisation des variables en CSS (avec exemples)

Introduction à l'utilisation des variables en CSS (avec exemples)

Nov 24, 2018 pm 02:52 PM
css

Cet article vous apporte une introduction à l'utilisation des variables en CSS (avec des exemples). Il a une certaine valeur de référence. Les amis dans le besoin peuvent s'y référer. aidé.

Il y a deux jours, j'ai vu l'article de Ruan Dashen sur l'utilisation des variables en CSS et je l'ai réglé.

Cette nouvelle fonctionnalité CSS importante est déjà prise en charge par tous les principaux navigateurs. Cet article fournit une introduction complète sur la façon de l'utiliser, et vous constaterez que le CSS natif devient extrêmement puissant.

1. Déclaration des variables

Lors de la déclaration d'une variable, deux tirets (--) doivent être ajoutés devant le nom de la variable.

body {
  --foo: #7F583F;
  --bar: #F7EFD2;
}
Copier après la connexion

Dans le code ci-dessus, deux variables sont déclarées dans le sélecteur de corps : --foo et --bar.

Ils ne sont pas différents des propriétés formelles telles que la couleur et la taille de la police, mais ils n'ont pas de signification par défaut. Par conséquent, les variables CSS sont également appelées « propriétés personnalisées CSS ». Parce que les variables et les propriétés CSS personnalisées sont en fait la même chose.

Vous vous demandez peut-être pourquoi choisir deux lignes de conjonction (--) pour représenter les variables ? Parce que $foo est utilisé par Sass et @foo est utilisé par Less. Afin d'éviter les conflits, les variables CSS officielles utilisent à la place deux lignes de conjonction.

Diverses valeurs peuvent être mises dans les variables CSS.

:root{
  --main-color: #4d4e53;
  --main-bg: rgb(255, 255, 255);
  --logo-border-color: rebeccapurple;

  --header-height: 68px;
  --content-padding: 10px 20px;

  --base-line-height: 1.428571429;
  --transition-duration: .35s;
  --external-link: "external link";
  --margin-top: calc(2vh + 20px);
}
Copier après la connexion

Les noms de variables sont sensibles à la casse. --header-color et --Header-Color sont deux variables différentes.

2. La fonction var()

var() est utilisée pour lire les variables.

a {
  color: var(--foo);
  text-decoration-color: var(--bar);
}
Copier après la connexion

var()La fonction peut également utiliser un deuxième paramètre pour représenter la valeur par défaut de la variable. Si la variable n'existe pas, cette valeur par défaut sera utilisée.

color: var(--foo, #7F583F);
Copier après la connexion

Le deuxième paramètre ne gère pas les virgules ou les espaces internes et est considéré comme faisant partie du paramètre.

var(--font-stack, "Roboto", "Helvetica");
var(--pad, 10px 15px 20px);
Copier après la connexion

var()La fonction peut également être utilisée dans la déclaration de variables.

:root {
  --primary-color: red;
  --logo-text: var(--primary-color);
}
Copier après la connexion

Notez que les valeurs de variables ne peuvent être utilisées que comme valeurs d'attribut, pas comme noms d'attribut.

.foo {
  --side: margin-top;
  /* 无效 */
  var(--side): 20px;
}
Copier après la connexion

Dans le code ci-dessus, la variable --side est utilisée comme nom d'attribut, ce qui n'est pas valide.

3. Type de valeur de variable

Si la valeur de variable est une chaîne, elle peut être concaténée avec d'autres chaînes.

--bar: 'hello';
--foo: var(--bar)' world';
Copier après la connexion

En utilisant ceci, vous pouvez déboguer (exemple).

body:after {
  content: '--screen-category : 'var(--screen-category);
}
Copier après la connexion

Si la valeur de la variable est une valeur numérique, elle ne peut pas être utilisée directement avec l'unité numérique.

.foo {
  --gap: 20;
  /* 无效 */
  margin-top: var(--gap)px;
}
Copier après la connexion

Dans le code ci-dessus, la valeur et l'unité sont écrites directement ensemble, ce qui n'est pas valide. Vous devez utiliser la fonction calc() pour les connecter.

.foo {
  --gap: 20;
  margin-top: calc(var(--gap) * 1px);
}
Copier après la connexion

Si la valeur de la variable a une unité, elle ne peut pas être écrite sous forme de chaîne.

/* 无效 */
.foo {
  --foo: '20px';
  font-size: var(--foo);
}

/* 有效 */
.foo {
  --foo: 20px;
  font-size: var(--foo);
}
Copier après la connexion

4. Portée

La même variable CSS peut être déclarée dans plusieurs sélecteurs. Lors de la lecture, l'instruction ayant la priorité la plus élevée prend effet. Ceci est cohérent avec la règle CSS « cascade ».

Voici un exemple.

<style>
  :root { --color: blue; }
  p { --color: green; }
  #alert { --color: red; }
  * { color: var(--color); }</style><p>蓝色</p><p>绿色</p><p id="alert">红色</p>
Copier après la connexion

Dans le code ci-dessus, les trois sélecteurs déclarent la variable --color. Lorsque différents éléments lisent cette variable, la règle avec la priorité la plus élevée sera utilisée, donc les couleurs des trois paragraphes de texte sont différentes.

C'est-à-dire que la portée d'une variable est la portée valide du sélecteur dans lequel elle se trouve.

body {
  --foo: #7F583F;
}

.content {
  --bar: #F7EFD2;
}
Copier après la connexion

Dans le code ci-dessus, la portée de la variable --foo est la portée effective du sélecteur de corps, et la portée de --bar est la portée effective du sélecteur .content.

Pour cette raison, les variables globales sont généralement placées à l'intérieur de l'élément racine :root pour garantir que tout sélecteur puisse les lire.

:root {
  --main-color: #06c;
}
Copier après la connexion

5. Mise en page responsive

Le CSS est dynamique, et toute modification de la page entraînera des changements dans les règles adoptées.

Grâce à cette fonctionnalité, vous pouvez déclarer des variables dans la commande multimédia de la mise en page réactive, de sorte que différentes largeurs d'écran aient des valeurs de variables différentes.

body {
  --primary: #7F583F;
  --secondary: #F7EFD2;
}

a {
  color: var(--primary);
  text-decoration-color: var(--secondary);
}

@media screen and (min-width: 768px) {
  body {
    --primary:  #F7EFD2;
    --secondary: #7F583F;
  }
}
Copier après la connexion

6. Traitement de compatibilité

Pour les navigateurs qui ne prennent pas en charge les variables CSS, vous pouvez utiliser la méthode d'écriture suivante.

a {
  color: #7F583F;
  color: var(--primary);
}
Copier après la connexion

peut également être détecté à l'aide de la commande @support.

@supports ( (--a: 0)) {
  /* supported */
}
@supports ( not (--a: 0)) {
  /* not supported */
}
Copier après la connexion

7. Opération JavaScript

JavaScript peut également détecter si le navigateur prend en charge les variables CSS.

const isSupported =
  window.CSS &&
  window.CSS.supports &&
  window.CSS.supports(&#39;--a&#39;, 0);

if (isSupported) {
  /* supported */
} else {
  /* not supported */
}
Copier après la connexion

JavaScript exploite les variables CSS comme suit.

// 设置变量
document.body.style.setProperty(&#39;--primary&#39;, &#39;#7F583F&#39;);

// 读取变量
document.body.style.getPropertyValue(&#39;--primary&#39;).trim();
// &#39;#7F583F&#39;

// 删除变量
document.body.style.removeProperty(&#39;--primary&#39;);
Copier après la connexion

Cela signifie que JavaScript peut stocker des valeurs arbitraires dans des feuilles de style. Ce qui suit est un exemple d'écoute d'un événement et les informations sur l'événement sont stockées dans une variable CSS.

const docStyle = document.documentElement.style;

document.addEventListener(&#39;mousemove&#39;, (e) => {
  docStyle.setProperty(&#39;--mouse-x&#39;, e.clientX);
  docStyle.setProperty(&#39;--mouse-y&#39;, e.clientY);
});
Copier après la connexion

Les informations qui ne sont pas utiles pour CSS peuvent également être placées dans des variables CSS.

--foo: if(x > 5) this.width = 10;
Copier après la connexion

Dans le code ci-dessus, la valeur de --foo est une instruction invalide en CSS, mais elle peut être lue par JavaScript. Cela signifie que vous pouvez écrire des paramètres de style dans des variables CSS et laisser JavaScript les lire.

Ainsi, les variables CSS permettent à JavaScript de communiquer avec CSS.

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

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Commandes de chat et comment les utiliser
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

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)

Comment écrire des lignes fendues sur bootstrap Comment écrire des lignes fendues sur bootstrap Apr 07, 2025 pm 03:12 PM

Il existe deux façons de créer une ligne divisée bootstrap: en utilisant la balise, qui crée une ligne divisée horizontale. Utilisez la propriété CSS Border pour créer des lignes de fractionnement de style personnalisées.

Les rôles de HTML, CSS et JavaScript: responsabilités de base Les rôles de HTML, CSS et JavaScript: responsabilités de base Apr 08, 2025 pm 07:05 PM

HTML définit la structure Web, CSS est responsable du style et de la mise en page, et JavaScript donne une interaction dynamique. Les trois exercent leurs fonctions dans le développement Web et construisent conjointement un site Web coloré.

Comment insérer des photos sur bootstrap Comment insérer des photos sur bootstrap Apr 07, 2025 pm 03:30 PM

Il existe plusieurs façons d'insérer des images dans Bootstrap: insérer directement les images, en utilisant la balise HTML IMG. Avec le composant d'image bootstrap, vous pouvez fournir des images réactives et plus de styles. Définissez la taille de l'image, utilisez la classe IMG-FLUID pour rendre l'image adaptable. Réglez la bordure en utilisant la classe IMG-border. Réglez les coins arrondis et utilisez la classe Roundée IMG. Réglez l'ombre, utilisez la classe Shadow. Redimensionner et positionner l'image, en utilisant le style CSS. À l'aide de l'image d'arrière-plan, utilisez la propriété CSS d'image d'arrière-plan.

Comment utiliser Bootstrap en Vue Comment utiliser Bootstrap en Vue Apr 07, 2025 pm 11:33 PM

L'utilisation de bootstrap dans vue.js est divisée en cinq étapes: installer bootstrap. Importer un bootstrap dans main.js. Utilisez le composant bootstrap directement dans le modèle. Facultatif: style personnalisé. Facultatif: utilisez des plug-ins.

Comment redimensionner le bootstrap Comment redimensionner le bootstrap Apr 07, 2025 pm 03:18 PM

Pour ajuster la taille des éléments dans Bootstrap, vous pouvez utiliser la classe de dimension, qui comprend: ajuster la largeur: .col-, .w-, .mw-ajustement Hauteur: .h-, .min-h-, .max-h-

Comment configurer le cadre de bootstrap Comment configurer le cadre de bootstrap Apr 07, 2025 pm 03:27 PM

Pour configurer le framework Bootstrap, vous devez suivre ces étapes: 1. Référez le fichier bootstrap via CDN; 2. Téléchargez et hébergez le fichier sur votre propre serveur; 3. Incluez le fichier bootstrap dans HTML; 4. Compiler les sass / moins au besoin; 5. Importer un fichier personnalisé (facultatif). Une fois la configuration terminée, vous pouvez utiliser les systèmes, composants et styles de grille de Bootstrap pour créer des sites Web et des applications réactifs.

Comment utiliser le bouton bootstrap Comment utiliser le bouton bootstrap Apr 07, 2025 pm 03:09 PM

Comment utiliser le bouton bootstrap? Introduisez Bootstrap CSS pour créer des éléments de bouton et ajoutez la classe de bouton bootstrap pour ajouter du texte du bouton

Comment afficher la date de bootstrap Comment afficher la date de bootstrap Apr 07, 2025 pm 03:03 PM

Réponse: Vous pouvez utiliser le composant de sélecteur de date de bootstrap pour afficher les dates dans la page. Étapes: Présentez le framework bootstrap. Créez une boîte d'entrée de sélecteur de date dans HTML. Bootstrap ajoutera automatiquement des styles au sélecteur. Utilisez JavaScript pour obtenir la date sélectionnée.

See all articles