Maison > interface Web > tutoriel CSS > analyse du sélecteur de pseudo-classe d'apprentissage du pseudo-sélecteur css

analyse du sélecteur de pseudo-classe d'apprentissage du pseudo-sélecteur css

青灯夜游
Libérer: 2022-08-03 11:27:03
original
2599 Les gens l'ont consulté

Dans l'article précédent "Apprentissage des pseudo-sélecteurs CSS : analyse des sélecteurs de pseudo-éléments", nous avons découvert les sélecteurs de pseudo-éléments, et aujourd'hui, nous examinons de plus près les sélecteurs de pseudo-classes, j'espère que cela sera utile à tout le monde. !

analyse du sélecteur de pseudo-classe d'apprentissage du pseudo-sélecteur css

Sélecteur de pseudo-classe

Le sélecteur de pseudo-classe est une utilisation qui permet de localiser des éléments HTML grâce à des informations d'état non contenues dans l'élément HTML. L'utilisation spécifique du sélecteur de pseudo-classe est d'ajouter des mots-clés au sélecteur existant pour représenter les informations d'état de l'élément HTML positionné. [Apprentissage recommandé : Tutoriel vidéo CSS]

Grâce aux pseudo-classes, les développeurs peuvent définir l'état dynamique des éléments, tels que le survol, le clic (actif) et les éléments du document qui ne peuvent pas être sélectionnés par d'autres sélecteurs (ces éléments Aucun attribut d'identifiant ou de classe), comme le premier enfant ou le dernier enfant.

Par exemple, le sélecteur de pseudo-classe :hover peut être utilisé pour changer la couleur d'un bouton lorsque l'utilisateur passe la souris dessus. Comme le montre l'exemple de code suivant : :hover伪类选择器可以用来在用户将鼠标悬停在按钮上时改变按钮的颜色。如下示例代码所示:

/* 所有用户指针悬停的按钮 */  
 button:hover {  
  color: blue;  
 }
Copier après la connexion

伪类的名称不区分大小写,但需要以冒号:开头。另外,伪类需要与 CSS 中的选择器结合使用,语法格式如下:

选择器:伪类 {  
  属性 : 属性值;  
 }
Copier après la connexion

伪类选择器 的具体语法格式为 :伪类,这里一定不要忘记 :

Copier après la connexion
Copier après la connexion
        <li>涂山红红     <li>涂山苏苏     <li>涂山蓉蓉     <li>涂山雅雅
Le nom de la pseudo-classe n'est pas sensible à la casse, mais doit commencer par deux points :. De plus, les pseudo-classes doivent être utilisées conjointement avec des sélecteurs en CSS. Le format de syntaxe est le suivant :

li:first-child {
    color: red;
}
li:last-child {
    color: blue;
}
Copier après la connexion
Copier après la connexion
🎜Le format de syntaxe spécifique du sélecteur de pseudo-classe🎜 est :pseudo-class. . N'oubliez pas ici :. 🎜🎜 Diverses pseudo-classes sont fournies en CSS, comme le montre le tableau suivant : 🎜 :enabled:first-child :first-of-typeinput:focusa:hoverinput:in-rangeinput:invalidcorrespond à l'avant-dernier élément enfant de l'élément parent

correspond à l'avant-dernier élément enfant de l'élément parent

correspond au deuxième élément enfant de l'élément parent

correspond à l'élément parent Le seul

-child

input:facultatifinput:hors plageinput:read-onlyinput:read-writeinput:requiredroot. #news:targetinput:valid correspond à tous les liens qui ont été visités
Selector Example Exemple de description
:active a:active match clicked link
:checked input:checked match < dans l'état sélectionné ;input>
:disabled input:disabled correspond à tous les éléments <input>
input:enabled correspond à chaque élément <input> activé
p:first-child correspond au premier élément de l'élément parent Child

, doit être le premier élément enfant de l'élément parent

p:first-of-type correspond au premier élément enfant de l'élément parent Un élément

:focus
correspond à l'élément <input> focalisé :hover
correspond à l'élément sur lequel la souris survole :in-range
correspond aux éléments <input> avec la plage de valeurs spécifiée :invalid
correspond à tous p:lang(it) correspond à chaque élément

dont la valeur de l'attribut lang commence par "it"

:last-child p :last-child correspond au dernier élément enfant dans l'élément parent,

doit être le dernier élément enfant de l'élément parent

:last-of-type p:last- of-type correspond au dernier élément

dans l'élément parent

:link a:link correspond à tous les liens non visités
:not(selector) :not (p) correspond à tous les éléments qui ne sont pas un

element

:nth-child(n) p:nth-child(2) correspond au deuxième élément enfant du parent
:nth-last -of-type(n) p:nth-last-of-type (2)
:nth-of-type(n) p:nth-of-type(2)
:only-of-type p:only-of-type
correspond au seul élément enfant de l'élément parent

:facultatif
correspond aux éléments <input> sans l'attribut "obligatoire" :out-of- range
correspond aux éléments <input> avec des valeurs en dehors de la plage spécifiée :lecture seule
correspond aux éléments <input> l'attribut "readonly" spécifié :read-write
ne correspond à aucun attribut "readonly" L'élément <input> :required
correspond <input> élément :root
correspondant à l'élément racine de l'élément, dans lequel l'attribut "required" est spécifié En HTML, l'élément racine est toujours HTML :target
correspond à l'élément #news actuellement actif (cliquez sur l'URL contenant ce nom d'ancre) :valid
correspond à tous les éléments <input> :visited a:visited

Classification des sélecteurs de pseudo-classe

La version CSS s'est développée de la première version à la troisième version, et le nombre de sélecteurs de pseudo-classe fournis est déjà énorme. En particulier, la version CSS3 a ajouté un grand nombre de sélecteurs de pseudo-classes. Il existe tellement de

sélecteurs de pseudo-classe Afin de mieux trier les sélecteurs de pseudo-classe, nous pouvons les diviser en 5 types suivants selon différentes utilisations :

    <li>

    Pseudo-classe de comportement utilisateur : fait référence aux utilisateurs Certaines pseudo-classes liées au comportement, comme survoler :hover, appuyer sur :active et obtenir le focus :focus, etc. :hover、按下:active以及获取焦点:focus等。

    <li>

    URL定位伪类:用于定位HTML页面中的元素

    <li>

    输入伪类:与表单控件相关的伪类

    <li>

    结构伪类:主要用于定位目标元素

    <li>

    逻辑组合伪类:用于逻辑操作的,例如:not(),就表示不是某元素。

1、用户行为伪类--动态伪类选择器

之所以称为动态伪类选择器,是因为它们根据条件的改变匹配元素,是相对于文档的固定状态来说的。随着JavaScript广泛用于修改文档内容和元素状态,动态选择器和静态选择器之间的界限越来越模糊,不过,动态伪类选择器仍然是一类比较特别的选择器。

:link选择器匹配超链接,:visited选择器匹配用户已经访问过得超链接。

使用:visited选择器可以应用到链接元素的属性不多。你可以改变颜色和字体,不过仅此而已。

提示::visited选择器匹配用户在所有页面访问过的href属性为URL的任意链接,而不只是你的页面。:visited最常见的用法就是针对已访问的链接应用某种样式,从而让它们跟未访问的链接有所区别。比如我们看新闻,看过的新闻和没有看过的新闻在首页列表呈现的状态是不一样的,便于我们区分。

:hover 选择器

:hover选择器匹配用户鼠标悬停在其上的任意元素。

:active 选择器

:active选择器匹配当前被用户激活的元素(一般情况下为鼠标点击该元素)。

:focus 选择器

:focus选择器匹配获得焦点的元素,常用于 input 元素。

2、结构性伪类选择器

使用结构性伪类选择器能够根据元素在文档中的位置选择元素。这类选择器都有一个冒号字符前缀(:),例如:empty。他们可以单独使用,也可以跟其他选择器组合使用,如p:empty。

结构伪类选择器类选择器包含的内容如下表所示:

Pseudo-classe de positionnement d'URL : utilisée pour localiser des éléments dans les pages HTML
伪类选择器 作用
selector:first-child 用来定位一组兄弟元素中的第一个元素
selector:last-child 用来定位一组兄弟元素中的最后一个元素
selector:nth-child(n) 用来定位一组兄弟元素中的第n个元素
selector:nth-last-child(n) 用来定位一组兄弟元素中倒序方式的第n个元素
selector:first-of-type 用来定位一组同类型的兄弟元素中的第一个元素
selector:last-of-type 用来定位一组同类型的兄弟元素中的最后一个元素
selector:nth-of-type(n) 用来定位一组同类型的兄弟元素中的第n个元素
selector:nth-last-of-type(n) 用来定位一组同类型的兄弟元素中倒序方式的第n个元素
selector:only-child 用来定位一个没有任何兄弟元素的元素
selector:only-of-type 用来定位一个没有任何同类型兄弟元素的元素
selector:empty 用来定位一个没有子级元素的元素,并且该元素也没有任何文本内容
selector:root 用来定位 HTML 页面中的根元素(
🎜Pseudo-classe d'entrée : pseudo-classe liée aux contrôles de formulaire🎜🎜🎜Pseudo-classe de structure : main Utilisé pour localiser l'élément cible🎜🎜🎜Pseudo-classe de combinaison logique : utilisée pour les opérations logiques, telles que :not(), ce qui signifie qu'il ne s'agit pas d'un certain élément. 🎜🎜🎜🎜1. Pseudo-classe de comportement de l'utilisateur - sélecteur de pseudo-classe dynamique🎜🎜🎜🎜La raison pour laquelle ils sont appelés sélecteurs de pseudo-classe dynamiques est qu'ils font correspondre les éléments en fonction des changements de conditions. . Par rapport à l'état fixe du document. Comme JavaScript est largement utilisé pour modifier le contenu des documents et l'état des éléments, les frontières entre les sélecteurs dynamiques et les sélecteurs statiques deviennent de plus en plus floues. Cependant, les sélecteurs de pseudo-classe dynamiques restent un type particulier de sélecteur. 🎜🎜 : Le sélecteur de lien correspond aux hyperliens et le sélecteur :visited correspond aux hyperliens que l'utilisateur a visités. 🎜🎜Utilisation du sélecteur : visité Il n'y a pas beaucoup d'attributs qui peuvent être appliqués aux éléments de lien. Vous pouvez modifier les couleurs et les polices, mais c'est tout. 🎜
🎜Astuce : Le sélecteur visité correspond à tout lien dont l'attribut href est une URL que l'utilisateur a visité sur toutes les pages, pas seulement sur votre page. L'utilisation la plus courante de :visited consiste à appliquer un certain style aux liens visités pour les distinguer des liens non visités. Par exemple, lorsque nous regardons les actualités, le statut des actualités que nous avons lues et des actualités que nous n'avons pas vues sont présentés dans différents états sur la liste de la page d'accueil, ce qui nous permet de les distinguer plus facilement. 🎜

🎜 : sélecteur de survol 🎜

🎜 : le sélecteur de survol correspond à tout élément sur lequel se trouve le survol de la souris de l'utilisateur. 🎜

🎜 : sélecteur actif 🎜

🎜 : le sélecteur actif correspond à l'élément actuellement activé par l'utilisateur (généralement l'élément est cliqué avec la souris). 🎜

🎜 : sélecteur de focus 🎜

🎜 : Le sélecteur de focus correspond à l'élément ciblé, souvent utilisé pour les éléments d'entrée. 🎜🎜🎜🎜2. Sélecteur de pseudo-classe structurelle🎜🎜🎜🎜Utilisez le sélecteur de pseudo-classe structurelle pour sélectionner les éléments en fonction de leur position dans le document. Ce type de sélecteur est préfixé par un caractère deux-points (:), par exemple : vide. Ils peuvent être utilisés seuls ou en combinaison avec d'autres sélecteurs, tels que p:empty. 🎜🎜Le contenu du sélecteur de classe du sélecteur de pseudo-classe de structure est présenté dans le tableau suivant : 🎜
🎜🎜selector:nth-last-child(n)🎜

Sélecteur de pseudo-classe Fonction
sélecteur :premier enfant🎜<td>Utilisé pour localiser le premier élément d'un groupe d'éléments frères🎜🎜</td> <tr> <td> <code>selector:last-child🎜 Utilisé pour localiser le premier élément dans un groupe d'éléments frères et sœurs Le dernier élément de 🎜🎜
selector:nth-child(n)🎜 est utilisé pour localiser le nième élément dans un groupe d'éléments frères et sœurs🎜 🎜
Utilisé pour localiser le nième élément dans un groupe d'éléments frères dans l'ordre inverse🎜🎜
selector :first-of-type🎜 Utilisé pour localiser le premier élément dans un groupe d'éléments frères du même type🎜🎜
selector:last- of-type code>🎜<td>Utilisé pour localiser le dernier élément d'un groupe d'éléments frères du même type🎜🎜</td> <tr><td><code>selector:nth-of-type(n) code>🎜<td> Utilisé pour localiser le nième élément dans un groupe d'éléments frères du même type🎜🎜</td> <tr> <td> <code>selector:nth-last-of-type(n)🎜 Utilisé pour localiser Le nième élément dans l'ordre inverse dans un groupe d'éléments frères du même type🎜🎜
selector:only-child🎜 est utilisé pour localiser un élément sans aucun élément frère🎜 🎜
selector:only-of-type🎜 Utilisé pour localiser un élément qui n'a aucun élément frère du même type🎜🎜
sélecteur : vide🎜 est utilisé pour localiser un élément qui n'a aucun élément enfant et l'élément n'a aucun contenu textuel🎜🎜
selector:root🎜 Utilisé pour localiser l'élément racine dans la page HTML ()🎜🎜🎜🎜

CSS中的结构伪类选择器是根据HTML页面中元素之间的关系来定位HTML元素,从而减少对HTML元素的id属性和class属性的依赖。

:first-child与:last-child

:first-child伪类用来定义一组兄弟元素的第一个元素而:last-child伪类则是定位一组兄弟元素的最后一个元素。

如下示例代码展示了:first-child伪类和:last-child伪类的用法:

HTML结构如下:

Copier après la connexion
Copier après la connexion
        <li>涂山红红     <li>涂山苏苏     <li>涂山蓉蓉     <li>涂山雅雅

CSS代码如下:

li:first-child {
    color: red;
}
li:last-child {
    color: blue;
}
Copier après la connexion
Copier après la connexion

代码运行结果如下图所示:

analyse du sélecteur de pseudo-classe dapprentissage du pseudo-sélecteur css

:first-child 伪类可以使用:nth-child(n)伪类改写为:nth-child(1),而:last-child伪类可以使用:nth-last-child(n)伪类改写为:nth-last-child(1)

:first-child伪类和:last-child伪类经常会引起误解。例如 li:first-child 是用来定位所有<li>元素中第一个作为子级元素的,而不是定位<li>元素的第一个子级元素。

:first-of-type与:last-of-type

:first-of-type伪类和:last-of-type伪类一个用于定位一组元素中的第一个兄弟元素,一个用来定位最后一个。

如下示例代码展示了:first-of-type伪类和:last-of-type伪类的用法:

HTML结构如下:

<h3>狐妖小红娘</h3>
<p>涂山红红</p>
<p>涂山苏苏</p>
Copier après la connexion

CSS代码如下:

p:first-of-type {
    color: red;
}

p:last-of-type {
    color: blue;
}
Copier après la connexion

代码运行结果如下图所示:

analyse du sélecteur de pseudo-classe dapprentissage du pseudo-sélecteur css

:first-of-type伪类与:last-of-type伪类的用法一定要和:first-child伪类与:last-child伪类的用法区分开。以:first-of-type伪类和:first-child伪类为例来说明:

    <li>

    :first-of-type伪类是定位一组同类型的兄弟元素中的第一个元素,不管这个元素在兄弟元素中的位置如何。

    <li>

    :first-child伪类是定位一组兄弟元素中的第一个元素,这些兄弟元素不一定是同类型的。

如果将上述示例代码中的:first-of-type伪类改写为:first-child伪类的话,将不会生效。

:nth-child(n)与:nth-last-child(n)

:nth-child(n)伪类和:nth-last-child(n)伪类都是CSS3中新增的选择器,这两个选择器的用法基本上是一致的。区别在于:nth-last-child(n)伪类是倒序方式定位元素,也就是说,:nth-last-child(n)伪类是从一组元素的结尾开始的。

接下来,主要以:nth-child(n)伪类为例进行讲解。:nth-child(n)伪类中的n参数的含义具有3种情况:

    <li>

    数字值:任意一个大于 0 的正整数。例如 #example td:nth-child(1) 表示定位ID为example的父元素下所有

元素中的第一个元素。<li>

关键字:odd表示奇数,等同于:nth-child(2n)even表示偶数,等同于:nth-child(2n+1)

<li>

格式为(an+b)公式:a表示周期的长度(步长 ),n表示计数器(从 0 开始 ),而b则表示偏移值。

如下示例代码展示了:nth-child(n)伪类(实现表格隔行换色效果)的用法:

nbsp;html>



    <meta>
    <meta>
    <meta>
    <title>nth-child伪类</title>
    <style>
        table {
            border-collapse: collapse;
            border-spacing: 0;
            width: 100%;
        }

        th,
        td {
            border-top: 1px solid lightcoral;
            text-align: center;
        }

        /* 最后一行单元格在底部增加一个边框效果 */
        tr:last-child td {
            border-bottom: 1px solid lightcoral;
        }

        /* 实现隔行换色 */
        tr:nth-child(even) {
            background-color: aquamarine;
        }
    </style>



    
Copier après la connexion
                                                                                                                                                                                                                                
姓名区域
梵云飞西西域
欢都落兰南国
石宽北山
涂山红红涂山

代码运行结果如下图所示:

analyse du sélecteur de pseudo-classe dapprentissage du pseudo-sélecteur css

:nth-child(n)伪类的n参数用法中比较复杂的是使用(an+b)公式用法,如下示例列举了一些公式用法:

    <li>

    :nth-child(5n):定位元素的序号是5 [=5×1]、10 [=5×2]、15 [=5×3]等。

    <li>

    :nth-child(3n+4):定位元素的序号是4 [=(3×0)+4]、7 [=(3×1)+4]、10 [=(3×2)+4]、13 [=(3×3)+4] 等。

    <li>

    :nth-child(-n+3):定位元素的序号是3 [=-0+3]、2 [=-1+3]、1 [=-2+3]。

:nth-child(n)伪类与:nth-last-child(n)伪类和:nth-of-type(n)伪类与:nth-last-of-type(n)伪类的区别,类似于:first-of-type伪类与:last-of-type伪类和:first-child伪类与:last-child伪类的区别。

:empty

:empty伪类是用来定位没有任何子级元素或文本内容的元素,其中文本内容包含了空白。但是HTML的注释是不影响:empty伪类定位元素的。

如下示例代码展示了:empty伪类的用法:

nbsp;html>



    <meta>
    <meta>
    <meta>
    <title>empty伪类</title>
    <style>
        body {
            /* 开启flex布局 */
            display: flex;
        }

        .box {
            background: pink;
            height: 80px;
            width: 80px;
            margin: 0 20px;
        }

        .box:empty {
            background: lime;
        }
    </style>



    <div></div>
    <div>这个元素的背景是粉色的</div>
    <div>
        <!-- 这是一个注释 -->
    </div>


Copier après la connexion

代码运行结果如下图所示:

analyse du sélecteur de pseudo-classe dapprentissage du pseudo-sélecteur css

:root

CSS中的:root伪类选择器比较简单,它代表的就是元素。

如下代码展示的:root伪类的用法:

:root {
    height: 100vh;
    width: 100vw;
    background-color: dodgerblue;
}
Copier après la connexion

代码运行结果如下图所示:

analyse du sélecteur de pseudo-classe dapprentissage du pseudo-sélecteur css

3、UI元素状态伪类选择器

使用UI伪类选择器可以根据元素的状态匹配元素,下方列表将简单总结这类选择器:

选择器 说明
:enabled 选择启用状态的元素
:disabled 选择禁用状态的元素
:checked 选择被选中的input元素(只用于单选按钮和复选框)
:default 选择默认元素
:valid 根据输入验证选择有效或者无效的input元素
:in-range/:out-of-range 选择在制定范围之内或者职位受限的input元素
:required/:optional 根据是否允许:required属性选择input元素

4、输入伪类选择器

关于表单输入的伪类,主要介绍三种常用的,具体如下:

    <li>

    :enabled:disabled

    <li>

    :read-only:read-write

    <li>

    :checked

:enabled和:disabled

:enabled:disabled一这组伪类选择器分别表示禁用状态与可用状态,这组为了使完全对立的。

:enabled伪类的实际用处并不大,因为大多元素默认都是可用的,所以写不写意义并不大。

如下代码展示了:enabled:disabled的用法:

nbsp;html>



  <meta>
  <meta>
  <meta>
  <title>:enabled和:disabled的用法</title>
  <style>
    input:enabled {
      outline: none;
    }

    input:disabled {
      /* 禁用状态背景为灰色 */
      background-color: gray;
    }
  </style>



  <input>
  <input>


Copier après la connexion

代码运行结果如下所示:

analyse du sélecteur de pseudo-classe dapprentissage du pseudo-sélecteur css

由上图我们看到禁用状态的<input>的背景颜色为灰色。

:read-only和:read-write

:read-only:read-write一这组伪类选择器分别表示只读和可写状态,同样的:read-write也很鸡肋,因为默认就是可读写,示例代码如下所示:

nbsp;html>



  <meta>
  <meta>
  <meta>
  <title>:read-only和:read-write</title>
  <style>
    input:read-write {
      outline: none;
    }

    /* 只读状态 */
    input:read-only {
      color: red;
      outline: none;
    }
  </style>



  <input>
  <input>


Copier après la connexion

代码运行结果如下所示:

analyse du sélecteur de pseudo-classe dapprentissage du pseudo-sélecteur css

我们可以看到,只读的<input>的文字颜色为红色。

:checked

:checked伪类可以说是众多伪类选择器中使用频率很高的一个伪类选择器,该选择器表示选中的状态,就比如下面这个例子:

nbsp;html>



  <meta>
  <meta>
  <meta>
  <title>checked伪类</title>
  <style>
    input:checked {
      /* 为选中的增加阴影 */
      box-shadow: 2px 2px 2px 2px lightcoral;
    }
  </style>



  <input>
  <input>


Copier après la connexion

analyse du sélecteur de pseudo-classe dapprentissage du pseudo-sélecteur css

关于:checked伪类,最佳实践是配合<label></label>元素来实现,现在我们就通过:checked<label></label>元素来实现一个开关的效果。

示例代码如下:

nbsp;html>



  <meta>
  <meta>
  <meta>
  <title>开关</title>
  <style>
    [type="checkbox"] {
      width: 44px;
      height: 26px;
      position: absolute;
      opacity: 0;
      pointer-events: none;
    }

    /* 开关样式 */
    .cs-switch {
      display: inline-block;
      width: 44px;
      height: 26px;
      border: 2px solid;
      border-radius: 26px;
      background-color: currentColor;
      box-sizing: border-box;
      color: silver;
      transition: all .2s;
      cursor: pointer;
    }

    .cs-switch::before {
      content: "";
      display: block;
      width: 22px;
      height: 22px;
      border-radius: 50%;
      background-color: #fff;
      transition: margin-left .2s;
    }


    :checked+.cs-switch {
      color: blueviolet;
    }

    /* 选中移动 */
    :checked+.cs-switch::before {
      margin-left: 18px;
    }

    /* 禁用状态 */
    :disabled+.cs-switch {
      opacity: .4;
      cursor: not-allowed;
    }
  </style>



  <!-- 普通状态 -->
  <input>
  <label></label>
  <!-- 选中状态 -->
  <input>
  <label></label>
  <!-- 禁用状态 -->
  <input>
  <label></label>
  <!-- 选中禁用状态 -->
  <input>
  <label></label>


Copier après la connexion

运行效果如下所示:

analyse du sélecteur de pseudo-classe dapprentissage du pseudo-sélecteur css

5、逻辑组合伪类

:not()否定的伪类

    <li>

    优先级为0,优先级由括号中的表达式决定; :not(p)由p决定

    <li>

    可以不断的级联;
    input:not(:disabled):not(:read-only) {} ;表示处于不禁用,也不处于只读的状态

    <li>

    不可出现多个表达式,也不支持选择符;
    li:not(li, od); 尚未支持

:not()的巨大的用处在于告别重置的问题;

重置web中的样式,就好比我们在项目中经常使用到的:添加.active类名来控制样式的显示与隐藏/改变样式,往常的写法都是:

.cs_li {
	display: none;
}
.cs_li.active {
	display: block;
}
Copier après la connexion

而我们可以使用:not()伪类,可以更好的实现:

.cs_li:not(.active) {
	display: none;
}
Copier après la connexion

在列表中的设置<li>的边框时也可使用其:not()

.cs_li:not(:nth-of-type(5n)){
	margin-right: 10px; // 除5的倍数项都设置右边的外边距
}
Copier après la connexion

:is()的作用是简化选择器

平时我们开发中经常会用到类似下面的语法:

.cs_li_a > img,
.cs_li_b > img,
.cs_li_c > img {
	display: none;
}
Copier après la connexion

使用:is()简化可写成:

:is(.cs_li_a, .cs_li_b, .cs_li_c) > img {
	display: none;
}
Copier après la connexion

还有一种嵌套之间的关系,相互嵌套,交叉组合得出结论;如下方所示

ol ol li,
ol ul li, 
ul ul li,
ul ol li {
	margin-left: 20px;
}
Copier après la connexion

使用:is()伪类强化,则只需要几行代码:

:is(ol, ul) :is(ol, ul) li{
	margin-left: 20px;
}
Copier après la connexion

<strong>:where()</strong>

:where()与上方的:is()相同,唯一不同的是级别永远为0,也不受括号里面的表达式影响;

使用的方法与:is()完全相同,但优先级永远是0;底下的括号中的优先级完全被忽略,俩句是同一个优先级,并且级别等同于.conten选择器

:where(.article, section) .conten {}
:where(#article, #section) .conten {
Copier après la connexion

(学习视频分享:web前端入门

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!

Étiquettes associées:
source:php.cn
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal