Heim >Web-Frontend >CSS-Tutorial >Erfahren Sie mehr über die @property-Funktion in CSS

Erfahren Sie mehr über die @property-Funktion in CSS

青灯夜游
青灯夜游nach vorne
2021-04-20 18:57:514501Durchsuche

Erfahren Sie mehr über die @property-Funktion in CSS

In diesem Artikel geht es hauptsächlich um eine sehr neue Funktion von CSS, CSS @property. Sein Aussehen hat die Fähigkeiten von CSS erheblich verbessert!

Laut MDN – CSS Property ist @property CSS at-rule Teil der CSS Houdini API, die es Entwicklern ermöglicht, ihre benutzerdefinierten CSS-Eigenschaften explizit zu definieren, die Überprüfung von Eigenschaftstypen zu ermöglichen, Standardwerte festzulegen und zu definieren, ob dies der Fall ist Benutzerdefinierte Eigenschaften können vererbt werden.

CSS Houdini Was ist das? CSS Houdini öffnet die zugrunde liegende API von CSS für Entwickler und ermöglicht es Entwicklern, CSS selbst über diese Schnittstellen zu erweitern und entsprechende bereitzustellen Mit dem Tool können Entwickler in den Stil- und Layoutprozess der Browser-Rendering-Engine eingreifen und so CSS-Code schreiben, den der Browser analysieren kann, wodurch neue CSS-Funktionalitäten entstehen. Dies steht natürlich nicht im Mittelpunkt dieses Artikels, wird aber ausführlich beschrieben. CSS Houdini 又是什么呢,CSS Houdini 开放 CSS 的底层 API 给开发者,使得开发者可以通过这套接口自行扩展 CSS,并提供相应的工具允许开发者介入浏览器渲染引擎的样式和布局流程中,使开发人员可以编写浏览器可以解析的 CSS 代码,从而创建新的 CSS 功能。当然,它不是本文的重点,不过多描述。

CSS Property 如何使用呢?我们将通过一些简单的例子快速上手,并且着重介绍它在 CSS 动画中起到的关键性的作用,对 CSS 动画带来的巨大提升。

示例

正常而言,我们定义和使用一个 CSS 自定义属性的方法是这样的:

:root {
    --whiteColor: #fff;
}

p {
    color: (--whiteColor);
}

而有了 @property 规则之后,我们还可以像下述代码这样去定义个 CSS 自定义属性:

<style>
@property --property-name {
  syntax: &#39;<color>&#39;;
  inherits: false;
  initial-value: #fff;
}

p {
    color: var(--property-name);
}
</style>

简单解读下:

  • @property --property-name 中的 --property-name 就是自定义属性的名称,定义后可在 CSS 中通过 var(--property-name) 进行引用
  • syntax:该自定义属性的语法规则,也可以理解为表示定义的自定义属性的类型
  • inherits:是否允许继承
  • initial-value:初始值

其中,@property 规则中的 syntax 和 inherits 描述符是必需的。

当然,在 JavaScript 内定义的写法也很简单,顺便一提:

<script>
CSS.registerProperty({
  name: "--property-name",
  syntax: "<color>",
  inherits: false,
  initialValue: "#c0ffee"
});
</script>

支持的 syntax 语法类型

syntax 支持的语法类型非常丰富,基本涵盖了所有你能想到的类型。

  • length
  • number
  • percentage
  • length-percentage
  • color
  • image
  • url
  • integer
  • angle
  • time
  • resolution
  • transform-list
  • transform-function
  • custom-ident (a custom identifier string)

syntax 中的 +#| 符号

定义的 CSS @property 变量的 syntax 语法接受一些特殊的类型定义。

  • syntax: '<color>'</color> :接受逗号分隔的颜色值列表
  • syntax: '<length>'</length> :接受以空格分隔的长度值列表
  • syntax: '<length length>'</length>:接受单个长度或者以空格分隔的长度值列表

OK,铺垫了这么多,那么为什么要使用这么麻烦的语法定义 CSS 自定义属性呢?CSS Houdini 定义的自定义变量的优势在哪里?下面我们一一娓娓道来。

使用 color syntax 语法类型作用于渐变

我们来看这样一个例子,我们有这样一个渐变的图案:

<div></div>
div {
    background: linear-gradient(45deg, #fff, #000);
}

Erfahren Sie mehr über die @property-Funktion in CSS

我们改造下上述代码,改为使用 CSS 自定义属性:

:root {
    --colorA: #fff;
    --colorB: #000;
}
div {
    background: linear-gradient(45deg, var(--colorA), var(--colorB));
}

得到的还是同样的一个渐变图:

Erfahren Sie mehr über die @property-Funktion in CSS

我们再加上一个过渡效果:

:root {
    --colorA: #fff;
    --colorB: #000;
}
div {
    background: linear-gradient(45deg, var(--colorA), var(--colorB));
    transition: 1s background;
    
    &:hover {
        --colorA: yellowgreen;
        --colorB: deeppink;
    }
}

看看鼠标 Hover 的时候,会发生什么:

Erfahren Sie mehr über die @property-Funktion in CSS

虽然我们设定了 1s 的过渡动画 transition: 1s background,但是很可惜,CSS 是不支持背景渐变色的直接过渡变化的,我们得到的只是两帧之间的之间变化。

使用 CSS @property 进行改造

OK,接下来我们就是有本文的主角,使用 Houdini API 中的 CSS 自定义属性替换原本的 CSS 自定义属性。

简单进行改造一下,使用 color syntax 语法类型:

@property --houdini-colorA {
  syntax: '<color>';
  inherits: false;
  initial-value: #fff;
}
@property --houdini-colorB {
  syntax: '<color>';
  inherits: false;
  initial-value: #000;
}
.property {
    background: linear-gradient(45deg, var(--houdini-colorA), var(--houdini-colorB));
    transition: 1s --houdini-colorA, 1s --houdini-colorB;
    
    &:hover {
        --houdini-colorA: yellowgreen;
        --houdini-colorB: deeppink;
    }
}</color></color>

我们使用了 @property 语法,定义了两个 CSS Houdini 自定义变量 --houdini-colorA--houdini-colorB

CSS-Eigenschaft Wie verwende ich sie? Wir beginnen schnell anhand einiger einfacher Beispiele und konzentrieren uns auf die Schlüsselrolle, die es in der CSS-Animation spielt, und auf die enorme Verbesserung, die es für die CSS-Animation mit sich bringt. 🎜

Beispiel

🎜Normalerweise definieren und verwenden wir eine benutzerdefinierte CSS-Eigenschaft wie folgt: 🎜
@property --colorA {
  syntax: '<color>';
  inherits: false;
  initial-value: fuchsia;
}
@property --colorC {
  syntax: '<color>';
  inherits: false;
  initial-value: #f79188;
}
@property --colorF {
  syntax: '<color>';
  inherits: false;
  initial-value: red;
}
div {
    background: linear-gradient(45deg,
        var(--colorA),
        var(--colorC),
        var(--colorF));
    animation: change 10s infinite linear;
}

@keyframes change {
    20% {
        --colorA: red;
        --colorC: #a93ee0;
        --colorF: fuchsia;
    }
    40% {
        --colorA: #ff3c41;
        --colorC: #e228a0;
        --colorF: #2e4c96;
    }
    60% {
        --colorA: orange;
        --colorC: green;
        --colorF: teal;
    }
    80% {
        --colorA: #ae63e4;
        --colorC: #0ebeff;
        --colorF: #efc371;
    }
}</color></color></color>
🎜Mit @property Nach dem Regeln können wir auch eine benutzerdefinierte CSS-Eigenschaft wie den folgenden Code definieren: 🎜<pre class="brush:php;toolbar:false">&lt;div&gt;&lt;/div&gt;</pre>🎜Kurze Interpretation: 🎜<ul> <li> <code>@property --property-name --property-name ist der Name der benutzerdefinierten Eigenschaft. Nach der Definition kann in CSS über var(--property-name) syntax referenziert werden: die Syntaxregeln von das benutzerdefinierte Attribut, das auch als Angabe des Typs des definierten benutzerdefinierten Attributs verstanden werden kann
  • inherits: ob Vererbung zulässig ist
  • initial-value: initial value ul>🎜Unter diesen sind die Syntax und die erbten Deskriptoren in der Regel @property erforderlich. 🎜🎜Natürlich ist auch die in JavaScript definierte Schreibmethode sehr einfach: 🎜
    .normal {
        width: 200px;
        height: 200px;
        border-radius: 50%;
        background: conic-gradient(yellowgreen, yellowgreen 25%, transparent 25%, transparent 100%); 
        transition: background 300ms;
        
        &:hover {
            background: conic-gradient(yellowgreen, yellowgreen 60%, transparent 60.1%, transparent 100%); 
        }
    }

    Unterstützte Syntax-Syntaxtypen

    🎜Syntax Die unterstützten Syntaxtypen sind sehr umfangreich und decken im Grunde alle erdenklichen Typen ab. 🎜
    • Länge
    • Anzahl
    • Prozentsatz
    • Längenprozentsatz
    • Farbe
    • Bild
    • URL
    • Ganzzahl
    • Winkel
    • Zeit
    • Auflösung
    • Transformationsliste
    • transform-function
    • custom-ident (eine benutzerdefinierte Kennungszeichenfolge)

    syntax +

  • , #, | Symbol🎜Die Syntaxsyntax der definierten CSS-@property-Variable akzeptiert einige spezielle Typdefinitionen . 🎜
    • Syntax: '<color>'</color>: Akzeptiert eine durch Kommas getrennte Liste von Farbwerten
    • Syntax: '<length>: akzeptiert eine durch Leerzeichen getrennte Liste von Längenwerten</length>
    • Syntax: '<length length>'</length>: akzeptiert eine einzelne Länge oder eine Durch Leerzeichen getrennte Liste Längenwertliste

    🎜OK, es wurde schon so viel dargelegt, warum also eine so umständliche Syntax verwenden, um benutzerdefinierte CSS-Eigenschaften zu definieren? Welche Vorteile haben benutzerdefinierte Variablen, die in CSS Houdini definiert sind? Lassen Sie uns einzeln darüber sprechen. 🎜

    Verwenden Sie den Syntaxtyp color, um auf Farbverläufe zu reagieren

    🎜Sehen wir uns ein solches Beispiel an. Wir haben ein solches Farbverlaufsmuster : 🎜
    @property --per {
      syntax: '<percentage>';
      inherits: false;
      initial-value: 25%;
    }
    
    div {
        background: conic-gradient(yellowgreen, yellowgreen var(--per), transparent var(--per), transparent 100%); 
        transition: --per 300ms linear;
        
        &:hover {
            --per: 60%;
        }
    }</percentage>
    @property --per {
      syntax: '<percentage> | <angle>';
      inherits: false;
      initial-value: 25%;
    }
    ...</angle></percentage>
    🎜Erfahren Sie mehr über die @property-Funktion in CSS🎜 🎜Wir transformieren. Laden Sie den obigen Code herunter und verwenden Sie stattdessen benutzerdefinierte CSS-Attribute: 🎜
    p {
        text-underline-offset: 1px;
        text-decoration-line: underline;
        text-decoration-color: #000;
        transition: all .3s;
        
        &:hover {
            text-decoration-color: orange;
            text-underline-offset: 10px;
            color: orange;
        }
    }
    🎜Sie erhalten immer noch das gleiche Verlaufsbild: 🎜🎜Erfahren Sie mehr über die @property-Funktion in CSS🎜🎜Wir fügen einen Übergangseffekt hinzu: 🎜
    @property --offset {
      syntax: '<length>';
      inherits: false;
      initial-value: 0;
    }
    div {
        text-underline-offset: var(--offset, 1px);
        text-decoration: underline;
        transition: --offset 400ms, text-decoration-color 400ms;
        
        &:hover {
            --offset: 10px;
            color: orange;
        text-decoration-color: orange;
        }
    }</length>
    🎜Sehen Sie sich an, was passiert, wenn die Maus darüber schwebt: 🎜🎜Erfahren Sie mehr über die @property-Funktion in CSS🎜🎜Obwohl wir 1s eingestellt haben Die Übergangsanimation Übergang: 1s Hintergrund, aber leider unterstützt CSS keine direkten Übergangsänderungen von Hintergrundverlaufsfarben. Was wir erhalten, ist nur der Wechsel zwischen zwei Frames. 🎜

    Verwenden Sie CSS @property für die Transformation

    🎜OK, als nächstes haben wir den Protagonisten dieses Artikels, der benutzerdefinierte CSS-Eigenschaften in der Houdini-API verwendet, um die ursprüngliche CSS-Anpassungseigenschaft zu ersetzen. 🎜🎜Einfache Transformation, verwenden Sie die Syntax color: 🎜
    html, body {
        width: 100%;
        height: 100%;
    }
    body {
        background-image:
            radial-gradient(
                circle at 86% 7%,
                rgba(40, 40, 40, 0.04) 0%,
                rgba(40, 40, 40, 0.04) 50%,
                rgba(200, 200, 200, 0.04) 50%,
                rgba(200, 200, 200, 0.04) 100%
            ),
            radial-gradient(
                circle at 15% 16%,
                rgba(99, 99, 99, 0.04) 0%,
                rgba(99, 99, 99, 0.04) 50%,
                rgba(45, 45, 45, 0.04) 50%,
                rgba(45, 45, 45, 0.04) 100%
            ),
            radial-gradient(
                circle at 75% 99%,
                rgba(243, 243, 243, 0.04) 0%,
                rgba(243, 243, 243, 0.04) 50%,
                rgba(37, 37, 37, 0.04) 50%,
                rgba(37, 37, 37, 0.04) 100%
            ),
            linear-gradient(rgb(34, 222, 237), rgb(135, 89, 215));
    }
    🎜Wir haben die Syntax @property verwendet und zwei benutzerdefinierte CSS-Houdini-Variablen - -houdini-colorA definiert. code> und <code>--houdini-colorB, ändern Sie diese beiden Farben, wenn sich der Mauszeiger ändert. 🎜

    需要关注的是,我们设定的过渡语句 transition: 1s --houdini-colorA, 1s --houdini-colorB,在这里,我们是针对 CSS Houdini 自定义变量设定过渡,而不是针对 background 设定过渡动画,再看看这次的效果:

    Erfahren Sie mehr über die @property-Funktion in CSS

    Wow,成功了,渐变色的变化从两帧的逐帧动画变成了补间动画,实现了从一个渐变色过渡到另外一个渐变色的效果!而这,都得益于 CSS Houdini 自定义变量的强大能力!

    CodePen Demo -- CSS Houdini 自定义变量实现渐变色过渡动画

    使用 CSS @property 实现渐变背景色过渡动画

    在上述的 DEMO 中,我们利用了 CSS Houdini 自定义变量,将原本定义在 background 的过渡效果嫁接到了 color 之上,而 CSS 是支持一个颜色变换到另外一个颜色的,这样,我们巧妙的实现了渐变背景色的过渡动画。

    在之前我们有讨论过在 CSS 中有多少种方式可以实现渐变背景色过渡动画 -- 巧妙地制作背景色渐变动画!,到今天,我们又多了一种实现的方式!

    @property --colorA {
      syntax: '<color>';
      inherits: false;
      initial-value: fuchsia;
    }
    @property --colorC {
      syntax: '<color>';
      inherits: false;
      initial-value: #f79188;
    }
    @property --colorF {
      syntax: '<color>';
      inherits: false;
      initial-value: red;
    }
    div {
        background: linear-gradient(45deg,
            var(--colorA),
            var(--colorC),
            var(--colorF));
        animation: change 10s infinite linear;
    }
    
    @keyframes change {
        20% {
            --colorA: red;
            --colorC: #a93ee0;
            --colorF: fuchsia;
        }
        40% {
            --colorA: #ff3c41;
            --colorC: #e228a0;
            --colorF: #2e4c96;
        }
        60% {
            --colorA: orange;
            --colorC: green;
            --colorF: teal;
        }
        80% {
            --colorA: #ae63e4;
            --colorC: #0ebeff;
            --colorF: #efc371;
        }
    }</color></color></color>

    Erfahren Sie mehr über die @property-Funktion in CSS

    完整的代码可以戳这里:

    CodePen Demo -- CSS Houdini 自定义变量实现渐变色过渡动画2

    conic-gradient 配合 CSS @property 实现饼图动画

    OK,上面我们演示了 syntaxcolor 语法类型的情况。在文章一开头,我们还列举了非常多的 syntax 类型。

    下面我们尝试下其他的类型,使用 percentage 百分比类型或者 angle 角度类型,实现一个饼图的 hover 动画。

    如果我们还是使用传统的写法,利用角向渐变实现不同角度的饼图:

    <div></div>
    .normal {
        width: 200px;
        height: 200px;
        border-radius: 50%;
        background: conic-gradient(yellowgreen, yellowgreen 25%, transparent 25%, transparent 100%); 
        transition: background 300ms;
        
        &:hover {
            background: conic-gradient(yellowgreen, yellowgreen 60%, transparent 60.1%, transparent 100%); 
        }
    }

    将会得到这样一种效果,由于 conic-gradient 也是不支持过渡动画的,得到的是一帧向另外一帧的直接变化:

    Erfahren Sie mehr über die @property-Funktion in CSS

    好,使用 CSS Houdini 自定义变量改造一下:

    @property --per {
      syntax: '<percentage>';
      inherits: false;
      initial-value: 25%;
    }
    
    div {
        background: conic-gradient(yellowgreen, yellowgreen var(--per), transparent var(--per), transparent 100%); 
        transition: --per 300ms linear;
        
        &:hover {
            --per: 60%;
        }
    }</percentage>

    看看改造后的效果:

    Erfahren Sie mehr über die @property-Funktion in CSS

    CodePode Demo -- conic-gradient 配合 CSS @property 实现饼图动画

    以往使用纯 CSS 非常复杂才能实现的效果,如果可以轻松的达成,不得不感慨 CSS @property 强大的能力!

    syntax 的 | 符号

    顺便演示一下定义 Houdini 自定义变量时 syntax 的一些稍微复杂点的用法。

    conic-gradient 中,我们可以使用百分比也可以使用角度作为关键字,上述的 DEMO 也可以改造成这样:

    @property --per {
      syntax: '<percentage> | <angle>';
      inherits: false;
      initial-value: 25%;
    }
    ...</angle></percentage>

    表示,我们的自定义属性即可以是一个百分比值,也可以是一个角度值。

    除了 | 符号外,还有 +# 号分别表示接受以空格分隔、和以逗号分隔的属性,感兴趣的可以自行尝试。

    使用 length 类型作用于一些长度变化

    掌握了上述的技巧,我们就可以利用 Houdini 自定义变量的这个能力,去填补修复以前无法直接过渡动画的一些效果了。

    过去,我们想实现这样一个文字下划线的 Hover 效果:

    p {
        text-underline-offset: 1px;
        text-decoration-line: underline;
        text-decoration-color: #000;
        transition: all .3s;
        
        &:hover {
            text-decoration-color: orange;
            text-underline-offset: 10px;
            color: orange;
        }
    }

    因为 text-underline-offset 不支持过渡动画,得到的结果如下:

    Erfahren Sie mehr über die @property-Funktion in CSS

    使用 Houdini 自定义变量改造,化腐朽为神奇:

    @property --offset {
      syntax: '<length>';
      inherits: false;
      initial-value: 0;
    }
    div {
        text-underline-offset: var(--offset, 1px);
        text-decoration: underline;
        transition: --offset 400ms, text-decoration-color 400ms;
        
        &:hover {
            --offset: 10px;
            color: orange;
        text-decoration-color: orange;
        }
    }</length>

    可以得到丝滑的过渡效果:

    Erfahren Sie mehr über die @property-Funktion in CSS

    CodePen Demo - Underlines hover transition(Chrome solution with Houdini)

    实战一下,使用 CSS @property 配合 background 实现屏保动画

    嗯,因为 CSS @property 的存在,让以前需要非常多 CSS 代码的工作,一下子变得简单了起来。

    我们尝试利用 CSS @property 配合 background,简单的实现一个屏保动画。

    我们利用 background 可以简单的得到这样一个图形,代码如下:

    html, body {
        width: 100%;
        height: 100%;
    }
    body {
        background-image:
            radial-gradient(
                circle at 86% 7%,
                rgba(40, 40, 40, 0.04) 0%,
                rgba(40, 40, 40, 0.04) 50%,
                rgba(200, 200, 200, 0.04) 50%,
                rgba(200, 200, 200, 0.04) 100%
            ),
            radial-gradient(
                circle at 15% 16%,
                rgba(99, 99, 99, 0.04) 0%,
                rgba(99, 99, 99, 0.04) 50%,
                rgba(45, 45, 45, 0.04) 50%,
                rgba(45, 45, 45, 0.04) 100%
            ),
            radial-gradient(
                circle at 75% 99%,
                rgba(243, 243, 243, 0.04) 0%,
                rgba(243, 243, 243, 0.04) 50%,
                rgba(37, 37, 37, 0.04) 50%,
                rgba(37, 37, 37, 0.04) 100%
            ),
            linear-gradient(rgb(34, 222, 237), rgb(135, 89, 215));
    }

    效果如下,还算可以的静态背景图:

    Erfahren Sie mehr über die @property-Funktion in CSS

    在往常,我们想让它动起来,其实是需要费一定的功夫的,而现在,通过 CSS @property,对我们希望进行动画的一些元素细节进行改造,可以得到非常不错的动画效果:

    body,
    html {
        width: 100%;
        height: 100%;
    }
    
    @property --perA {
      syntax: '<percentage>';
      inherits: false;
      initial-value: 75%;
    }
    
    @property --perB {
      syntax: '<percentage>';
      inherits: false;
      initial-value: 99%;
    }
    
    @property --perC {
      syntax: '<percentage>';
      inherits: false;
      initial-value: 15%;
    }
    
    @property --perD {
      syntax: '<percentage>';
      inherits: false;
      initial-value: 16%;
    }
    
    @property --perE {
      syntax: '<percentage>';
      inherits: false;
      initial-value: 86%;
    }
    
    @property --angle {
      syntax: '<angle>';
      inherits: false;
      initial-value: 0deg;
    }
    
    body {
        background-image: 
            radial-gradient(
                circle at var(--perE) 7%,
                rgba(40, 40, 40, 0.04) 0%,
                rgba(40, 40, 40, 0.04) 50%,
                rgba(200, 200, 200, 0.04) 50%,
                rgba(200, 200, 200, 0.04) 100%
            ),
            radial-gradient(
                circle at var(--perC) var(--perD),
                rgba(99, 99, 99, 0.04) 0%,
                rgba(99, 99, 99, 0.04) 50%,
                rgba(45, 45, 45, 0.04) 50%,
                rgba(45, 45, 45, 0.04) 100%
            ),
            radial-gradient(
                circle at var(--perA) var(--perB),
                rgba(243, 243, 243, 0.04) 0%,
                rgba(243, 243, 243, 0.04) 50%,
                rgba(37, 37, 37, 0.04) 50%,
                rgba(37, 37, 37, 0.04) 100%
            ),
            linear-gradient(var(--angle), rgb(34, 222, 237), rgb(135, 89, 215));
        animation: move 30s infinite alternate linear;
    }
    
    @keyframes move {
        100% {
            --perA: 85%;
            --perB: 49%;
            --perC: 45%;
            --perD: 39%;
            --perE: 70%;
            --angle: 360deg;
        }
    }</angle></percentage></percentage></percentage></percentage></percentage>

    效果如下(因为 Gif 上传大小限制,加快了速率,截取了其中一部分,简单做个示意):

    Erfahren Sie mehr über die @property-Funktion in CSS

    整体的效果还是挺不错的,完整的 Demo 你可以戳这里:

    CodePen Demo -- CSS @property PureCSS Wrapper

    参考文献:

    最后

    好了,本文到此结束,介绍了 CSS Houdini API 中的 CSS @property 部分,并且利用它实现了一些以往无法简单实现的动画效果,希望对你有帮助 :)

    更多编程相关知识,请访问:编程视频!!

    Das obige ist der detaillierte Inhalt vonErfahren Sie mehr über die @property-Funktion in CSS. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

    Stellungnahme:
    Dieser Artikel ist reproduziert unter:segmentfault.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen