Maison  >  Article  >  interface Web  >  Découvrez les nouvelles fonctionnalités de CSS3 @layer dans un seul article

Découvrez les nouvelles fonctionnalités de CSS3 @layer dans un seul article

青灯夜游
青灯夜游avant
2022-03-28 11:12:162643parcourir

Cet article vous donnera une compréhension approfondie de la nouvelle fonctionnalité @layer en CSS3. J'espère qu'il vous sera utile !

Découvrez les nouvelles fonctionnalités de CSS3 @layer dans un seul article

À l'aube de 2022, de nouvelles fonctionnalités de CSS émergent les unes après les autres, et la nouvelle fonctionnalité qui a le plus attiré l'attention dans le cercle CSS récemment n'est autre que CSS @layer.

Cet article utilisera le langage le plus concis pour permettre aux lecteurs de comprendre rapidement ce qu'est la nouvelle spécification CSS @layer.

Problèmes existant dans les priorités CSS dans le passé

S'il y a beaucoup de styles sur notre page, tels que des styles personnalisés lorsque nous développons la page et des styles de bibliothèque de composants importés. À cette époque, le style sera très déroutant et difficile à gérer.

Lorsque nous souhaitons remplacer certains styles qui ne sont pas écrits par nous, nous devons souvent remplacer ces styles en utilisant des noms de style avec un poids de priorité plus élevé.

Dans le même temps, lorsque la priorité du style semble difficile à contrôler, les développeurs ont l'habitude d'abuser de !important pour la résoudre, ce qui conduit à une structure de style plus déroutante à l'avenir. !important 去解决,这又循环导致了后续更混乱的样式结构。

基于让 CSS 得到更好的控制和管理的背景,CSS @layer 应运而生。

何为 CSS @layer?

CSS @layer 从 CSS Cascading and Inheritance Level 5 被规范定义。

何为 CSS @layer?简单而言,CSS @规则 中的@layer声明了一个 级联层, 同一层内的规则将级联在一起, 这给予了开发者对层叠机制的更多控制。

语法也非常简单,看这样一个例子:

@layer utilities {
  /* 创建一个名为 utilities 的级联层 */
}

这样,我们就创建一个名为 utilities 的 @layer 级联层。

@layer 级联层如何使用呢?

通过 @layer 级联层管理样式优先级

@layer 级联层最大的功能,就是用于控制不同样式之间的优先级

看下面这样一个例子,我们定义了两个 @layer 级联层 A 和 B:

<div></div>
div {
    width: 200px;
    height: 200px;
}
@layer A {
    div {
        background: blue;
    }
}
@layer B {
    div {
        background: green;
    }
}

由于 @layer B 的顺序排在 @layer A 之后,所以 @layer B 内的所有样式优先级都会比 @layer A 高,最终 div 的颜色为 green

Découvrez les nouvelles fonctionnalités de CSS3 @layer dans un seul article

当然,如果页面内的 @layer 太多,可能不太好记住所有 @layer 的顺序,因此,还有这样一种写法。

我们可以同时命名多个 @layer 层,其后再补充其中的样式规则。

<div></div>
@layer B, C, A;
div {
    width: 200px;
    height: 200px;
}
@layer A {
    div {
        background: blue;
    }
}
@layer B {
    div {
        background: green;
    }
}
@layer C {
    div {
        background: orange;
    }
}

上述代码,我们首先定义了 @layer B, C, A 三个 @layer 级联层。而后再后面的 CSS 代码中补充了每个级联层的 CSS 代码,但是样式的优先级为:

A > C > B

因此,最终的 div 的颜色值为 @layer A 中定义的颜色,为 blue

Dans le but de permettre à CSS d'être mieux contrôlé et géré, CSS @layer a vu le jour.

Qu'est-ce que CSS @layer ? Découvrez les nouvelles fonctionnalités de CSS3 @layer dans un seul articleCSS @layer de CSS Cascading and Inheritance Level 5

est défini par la spécification.

Qu'est-ce que CSS @layer ? En termes simples, CSS @ layer dans @rule déclare une couche en cascade. Les règles de la même couche seront mises en cascade ensemble, ce qui donne aux développeurs plus de contrôle sur le mécanisme de cascade.

La syntaxe est également très simple, regardez cet exemple :

@layer utilities {
  p {
    padding: .5rem;
  }
}

De cette façon, nous créons une couche en cascade @layer nommée utility.

@layer Comment utiliser les calques en cascade ?

Gérer la priorité des styles via la couche en cascade @layer

La fonction la plus importante de la couche en cascade @layer est de contrôler la priorité entre les différents styles

.

Regardez l'exemple suivant, nous avons défini deux couches en cascade @layer A et B :

@import(utilities.css) layer(utilities);
@layer utilities;
// ...
// ...
@layer utilities {
    p {
        color: red;
    }
}
Puisque @layer B est ordonné après @layer A Après cela, la priorité de tous les styles dans @layer B sera supérieure à celle de @layer A, et la couleur finale du div est vert :

De Bien sûr, si la page contient trop de @layers et qu'il n'est peut-être pas facile de se souvenir de l'ordre de tous les @layers, il existe donc une autre façon d'écrire.

Nous pouvons nommer plusieurs calques @layer en même temps, puis ajouter les règles de style.

@layer A { a { color: red; } }
@layer B { a { color: orange; } }
@layer C { a { color: yellow; } }
a { color: green; } /* 未被 @layer 包裹的样式 */
@layer {
  p {
    margin: 1rem;
  }
}
Dans le code ci-dessus, nous définissons d'abord trois couches en cascade @layer @layer B, C, A. Ensuite, le code CSS de chaque couche en cascade est ajouté au code CSS suivant, mais la priorité du style est :

A

> 🎜C🎜 > La couleur définie dans @layer A est bleu : 🎜🎜🎜🎜🎜À ce stade, le rôle du CSS @layer est clairement visible. 🎜🎜🎜En utilisant CSS @layer, nous pouvons diviser différents modules CSS en différents @layers et utiliser l'ordre pour contrôler la priorité globale du style🎜. 🎜🎜Trois façons d'introduire la définition de la couche en cascade @layer🎜🎜Les deux façons mentionnées ci-dessus d'introduire la définition de la couche en cascade @layer Nous allons la décrire à nouveau ici. Il existe un total de 3 façons d'introduire CSS @layer. couche en cascade. 🎜🎜1. Créez directement une règle @layer au niveau du bloc, qui contient des règles CSS qui agissent au sein du calque : 🎜
<div></div>
🎜2 Un calque en cascade peut être créé via 🎜@import🎜, et les règles existent dans le style importé In. le tableau : 🎜
div {
    width: 200px;
    height: 200px;
}
@layer {
    div {
        background: pink;
    }
}
@layer B, C, A;
@layer A {
    div {
        background: blue;
    }
}
@layer B {
    div {
        background: green;
    }
}
@layer C {
    div {
        background: orange;
    }
}
🎜3. Créez un calque en cascade nommé, mais ne spécifiez aucun style. Les styles peuvent ensuite être ajoutés n'importe où dans CSS : 🎜
div {
    width: 200px;
    height: 200px;
}
@layer B, C, A;
@layer A {
    div {
        background: blue;
    }
}
@layer B {
    div {
        background: green;
    }
}
@layer C {
    div {
        background: orange;
    }
}
@layer {
    div {
        background: pink;
    }
}
🎜🎜Priorité des calques d'habillage non @layer et des styles de style @layer dans le calque🎜🎜🎜Bien sûr, il y aura une situation où les styles qui ne sont pas enveloppés par @layer le seront ont la priorité. Comment la classe se compare-t-elle aux styles enveloppés dans @layer ? 🎜🎜Regardez cet exemple : 🎜
@layer A {
  @layer B{
    ...
  }
}
🎜Il y aura une conclusion très importante ici, 🎜Les styles enveloppés par non-@layer ont une priorité plus élevée que les styles enveloppés par @layer🎜, par conséquent, l'ordre des règles ci-dessus est : 🎜🎜 Styles non enveloppés par @layer> @layer C >

匿名层与嵌套层

还有两种层级关系,分别是匿名层嵌套层

匿名层

允许创建一个不带名字的 @layer:

@layer {
  p {
    margin: 1rem;
  }
}

这里,创建了一个匿名层。匿名层的两个重要特性:

  • 创建后无法向其再添加规则

  • 该层和其他命名层功能一致,优先级也遵循后定义的匿名层,比其他已定义的 @layer 层,优先级更高

看一个例子:

<div></div>
div {
    width: 200px;
    height: 200px;
}
@layer {
    div {
        background: pink;
    }
}
@layer B, C, A;
@layer A {
    div {
        background: blue;
    }
}
@layer B {
    div {
        background: green;
    }
}
@layer C {
    div {
        background: orange;
    }
}

上述代码,我们首先定义了一个匿名层,指定了 div 的颜色为 pink,而后又定义了 @layer B, C, A。这里优先级顺序为:

A > C > B > 匿名层

最终的颜色为 @layer A 内的颜色值 -- blue

Découvrez les nouvelles fonctionnalités de CSS3 @layer dans un seul article

如果,我们将匿名层放在最后的话:

div {
    width: 200px;
    height: 200px;
}
@layer B, C, A;
@layer A {
    div {
        background: blue;
    }
}
@layer B {
    div {
        background: green;
    }
}
@layer C {
    div {
        background: orange;
    }
}
@layer {
    div {
        background: pink;
    }
}

此时,样式的优先级顺序为:

匿名层 > A > C > B

最终的颜色为匿名层内的颜色值 -- pink

Découvrez les nouvelles fonctionnalités de CSS3 @layer dans un seul article

嵌套层

说完了匿名层,我们再来看看嵌套层。

顾名思义,嵌套层的意思就是在 @layer 内部,我们可以再嵌套使用 @layer 级联层。像是这样:

@layer A {
  @layer B{
    ...
  }
}

当然,它还有另外一种语法,上述代码等价于:

@layer A.B {
  ...
}

了解了这个后,那么,看这样一个例子:

<div></div>
div {
    width: 200px;
    height: 200px;
}
@layer A {
    div {
        background: blue;
    }
    
    @layer B {
        div {
            background: red;
        }
    }
}

我们在 @layer A 中嵌套一个 @layer B,同时都定义了一个 div 的样式,最终 div 的 background 到底是什么颜色呢?

最终为蓝色 background: blue,为什么呢?这个很好记忆,我们假设如果没有 @layer A 这一层包裹,其实就是上述说的 @layer 层与非 @layer 层的优先级比较,这里,非 @layer 层(我们可以理解为更高级别的一层 @layer)的优先级更高。

因此,对于单个 @layer 内的嵌套关系,样式优先级为:

@layer A > @layer A.B

多层嵌套层的优先级关系

OK,再看这样一种情况:

div {
    width: 200px;
    height: 200px;
}
@layer A {
    div {
        background: blue;
    }
    @layer B {
        div {
            background: red;
        }
    }
}
@layer C {
    div {
        background: yellow;
    }
    @layer D {
        div {
            background: green;
        }
    }
}

这里存在同时存在多个嵌套 @layer 的情况。那么这种情况优先级又是如何划分呢?

这里的规则是,优先级高的 @layer,无论是否存在嵌套,优先级都整体比优先级低的 @layer(无论是否存在嵌套)高,因此,这里的优先级排序是:

@layer C > @layer C.D > @layer A > @layer A.B

!important 对 CSS @layer 的影响

再来看看  !important 对 CSS @layer 的影响。

这里可以分为几种情况,先看其中一种:

<div></div>
div {
    width: 200px;
    height: 200px;
    background: black;
}
@layer A {
    div {
        background: blue;
    }
    @layer B {
        div {
            background: red;
        }
    }
}
@layer C {
    div {
        background: yellow;
    }
    @layer D {
        div {
            background: green!important;
        }
    }
}

上述代码,我们给 @layer C.D 的 <div> 添加了一个 <code>!important 规则。

如果,不考虑 !important 规则,那么实际的 CSS 优先级为(序号越高,优先级越高):

  • @layer A.B

  • @layer A

  • @layer C.D

  • @layer C

  • 非 layer 包裹块

那么,<div> 的颜色应该为黑色 <code>black。然而,这里给 @layer C.D 的 <div> 添加了一个 <code>!important 规则。

实际上,最终 <div> 的颜色为 <code>green,也就是最终的优先级排序为(序号越高,优先级越高):

  • @layer A.B

  • @layer A

  • @layer C

  • 非 layer 包裹块

  • !important 下的 @layer C.D

也就是说,这里 !important 规则的优先级还是凌驾于非 !important 规则之上的。

上述 DEMO 还是比较有意思的,感兴趣的可以看看:CodePen Demo -- CSS Cascade @layer Demo

https://codepen.io/Chokcoco/pen/KKZKBRr

非 @layer 包含块 !important 与 @layer 包含块 !important

到这里,你也许会以为你懂了。好,我们再来看一个 DEMO,如果我们给非 @layer 包含块,也加上一个 !important 规则,事情就变得有趣了。

<div></div>
div {
    width: 200px;
    height: 200px;
    background: black!important;
}
@layer A {
    div {
        background: blue;
    }
    @layer B {
        div {
            background: red;
        }
    }
}
@layer C {
    div {
        background: yellow;
    }
    @layer D {
        div {
            background: green!important;
        }
    }
}

仔细看上述代码,非 @layer 包含块,我们也加上了一个 !important 规则,按照上述我能描述的规则来看,非 @layer 包含块的优先级高于 @layer 包含块,那么正常而言,我们不难猜测,这里 background: black!important 的优先级应该要比 background: green!important 高,最终 <div> 应该展示黑色。<p>而实际上,这里最终 <code><div> 的颜色还是 <code>green。这里就又有一个非常有意思的知识点了,!important 下样式优先级的规则与非 !important 正常状态下刚好相反。

这是一个非常重要的特性,在比较正常(非 !important)规则时,越是级联(排序较后的 @layer 规则),优先级越低;反之,在比较 !important 规则时,越是级联靠后的(排序较后的 @layer 规则),优先级越高。

这个,更进一步的话,我们需要去了解 CSS Cascading 相关的知识了。

CSS Cascade 规范

在 CSS @layer 之前,我们简单看一张图:

上图表面的是在没有 CSS @layer 之前,CSS 样式申明的优先级排序,根据 CSS Cascading 4(Current Work) 标准,定义的当前规范下申明的层叠顺序优先级如下(越往下的优先级越高,下面的规则按升序排列):

  • Normal user agent declarations
  • Normal user declarations
  • Normal author declarations
  • Animation declarations
  • Important author declarations
  • Important user declarations
  • Important user agent declarations
  • Transition declarations

按照上述算法,可以得到一个样式优先级的排序,大概是这样(越往下的优先级越高,下面的规则按升序排列):

Découvrez les nouvelles fonctionnalités de CSS3 @layer dans un seul article

  • User Agent - 用户代理普通样式

  • User - 用户设置的普通样式

  • Author - 页面作者普通样式

  • Animations - 动画样式

  • ❗️Author - 页面作者 !important 样式

  • ❗️User - 用户设置的 !important 样式

  • ❗️User Agent - 用户代理的 !important 样式

  • Transitions - 过渡样式

简单解释一下用户代理样式:浏览器会有一个基本的样式表来给任何网页设置默认样式。这些样式统称用户代理样式页面作者样式:网页的作者可以定义文档的样式,这是最常见的样式表。大多数情况下此类型样式表会定义多个,它们构成网站的视觉和体验,即页面主题,可以理解为页面作者样式用户样式:读者,作为浏览器的用户,可以使用自定义样式表定制使用体验,自定义用户偏好,可以理解为用户样式

关于 CSS Cascading,也就是层叠规范,你可以看看我的这篇文章加深理解 -- 深入理解 CSS(Cascading Style Sheets)中的层叠(Cascading)。

https://github.com/chokcoco/iCSS/issues/76

而当有了 CSS @layer 之后,这个层叠优先级顺序有了更新,具体优先级如下:

Découvrez les nouvelles fonctionnalités de CSS3 @layer dans un seul article

整体会变更为复杂一些,但是总体还是遵循了两个规则:

  • !important 样式高于非 !important 样式

  • 在比较 !important 规则时,优先级顺序与正常规则相反,在正常状态下优先级越低的,在 !important 下优先级越高

总结一下

综上,便是关于 CSS @layer 的基础相关知识。

CSS @layer 的诞生,让我们有能力更好的划分页面的样式层级,更好的处理内部样式与外部引用样式的优先级顺序,属于比较重大的一次革新。

同时,它也让我们意识到要逐渐摒弃大规模使用 !important 去覆盖样式优先级的错误做法,避免许多因为优先级问题带来的不必要的副作用。

当然,时至今天(2022-03-14),我们来看一眼兼容性:

Découvrez les nouvelles fonctionnalités de CSS3 @layer dans un seul article

Bien qu'il soit devenu populaire, les dernières versions de Chrome, Safari, Firefox et Edge ont commencé à prendre en charge CSS @layer, et il peut déjà être utilisé dans un premier temps via certains polyfills, je pense qu'il sera utilisé prochainement. l'avenir. Deviendra une partie essentielle du code CSS de l'entreprise.

Lecture approfondie

Il y a eu de nombreuses discussions sur CSS @layer sur Internet. Voici quelques articles de haute qualité Si vous êtes intéressé, vous pouvez continuer à lire :

Enfin

Eh bien, cet article se termine ici, je j'espère que cela vous sera utile :)

(Apprenez le partage de vidéos : front-end 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!

firefox css chrome safari css3 edge 循环 样式表 !important background github 算法 https
Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer
Article précédent:Parlons de la façon d'utiliser les filtres CSS pour obtenir des coins arrondis concaves et lisses.Article suivant:Parlons de la façon d'utiliser les filtres CSS pour obtenir des coins arrondis concaves et lisses.

Articles Liés

Voir plus