用5个例子解释CSS变量

126 阅读6分钟
本文首发于微信公众号:大迁世界, 我的微信:qq449245884,我会第一时间和你分享前端行业趋势,学习途径等等。
更多开源作品请看 GitHub github.com/qq449245884… ,包含一线大厂面试完整考点、资料以及我的系列文章。

快来免费体验ChatGpt plus版本的,我们出的钱
体验地址:chat.waixingyun.cn
可以加入网站底部技术群,一起找bug.

随着 Web应用程序变得越来越大,CSS变得越来越大,越来越冗长,而且混乱不堪。 在良好的上下文中使用CSS变量,可为我们提供重用和轻松更改重复出现的CSS属性的机制。

在纯CSS支持变量之前,我们有像Less和Sass这样的预处理程序。但是它们需要在使用前进行编译,因此(有时)增加了一层额外的复杂性。

如何定义和使用CSS变量(也称为自定义属性)

要声明一个简单的 JS 变量,很简单,如下所示:

let myColor = "green";

要声明一个CSS变量,必须在该变量的名字前添加两个横线。

body {
    --english-green-color: #1B4D3E;
    }

现在,为了使用CSS变量的值,我们可以使用var(...)函数。

.my-green-component{
    background-color: var(--english-green-color);
    }

管理CSS变量的最简单方法是将它们声明在:root伪类中。 鉴于CSS变量与其他CSS定义一样都遵循规则,因此将它们放在:root中将确保所有选择器都可以访问这些变量。

:root{
    --english-green-color: #1B4D3E;
    }

览器对CSS变量的支持情况

浏览器对CSS变量的支持一点也不差。 如果查看 Can I Use CSS Variables 那会发现所有主流浏览器都支持CSS变量。 无论是在移动设备还是 PC 上。

现在,让我们看看这些CSS变量的实际作用。

示例1-管理颜色

使用CSS变量的最佳选择之一就是设计的颜色。 不必一遍又一遍地复制和粘贴相同的颜色,我们只需将它们放在变量中即可。

如果有该死的产品要我们更新特定的绿色阴影或将所有按钮设置为红色而不是蓝色,则只需更改该CSS变量的值即可。 我们无需搜索并替换所有出现的该颜色。

动手试试:codesandbox.io/s/8kkyl4mlm…

示例2-删除重复的代码

通常我们需要构建一些组件的不同变体。相同的基本样式,只是功能略有不同。我们举例使用一个带有不同颜色按钮的案例。

                      .btn:hover {
                        background: black;
                          // more props here
                          }
                          
                          .btn.red {
                            border-color: red
                            }
                            .btn.red:hover {
                              background: red
                              }" title="" data-bs-original-title="复制" aria-label="复制"></button>
</div>
.btn {
  border: 2px solid black;
    // more props here
    }
<span class="hljs-selector-class">.btn</span><span class="hljs-selector-pseudo">:hover</span> {
  <span class="hljs-attribute">background</span>: black;
    <span class="hljs-comment">// more props here</span>
    }
    
    <span class="hljs-selector-class">.btn</span><span class="hljs-selector-class">.red</span> {
      <span class="hljs-attribute">border-color</span>: red
      }
      <span class="hljs-selector-class">.btn</span><span class="hljs-selector-class">.red</span><span class="hljs-selector-pseudo">:hover</span> {
        <span class="hljs-attribute">background</span>: red
        }</pre><p>像这样使用它们:</p><div class="widget-codetool" style="display: none;">
      <div class="widget-codetool--inner">
                  <button type="button" class="btn btn-dark far fa-copy rounded-0 sflex-center copyCode" data-toggle="tooltip" data-placement="top" data-clipboard-text="<button class=&quot;btn&quot;>Hello</button>
                  <button class=&quot;btn red&quot;>Hello</button>" title="" data-bs-original-title="复制" aria-label="复制"></button>
</div>
      </div><pre class="hljs language-angelscript">&lt;button <span class="hljs-keyword">class</span>="<span class="hljs-symbol">btn</span>"&gt;<span class="hljs-symbol">Hello</span>&lt;/<span class="hljs-symbol">button</span>&gt;
      &lt;<span class="hljs-symbol">button</span> <span class="hljs-symbol">class</span>="<span class="hljs-symbol">btn</span> <span class="hljs-symbol">red</span>"&gt;<span class="hljs-symbol">Hello</span>&lt;/<span class="hljs-symbol">button</span>&gt;</pre><p>但是,这会增加一些代码重复。在<code>.red</code>类中,我们必须将边框颜色和背景都设置为红色。万一哪天需要更改颜色,那就很麻烦了,需要一个一个的改。这个问题可以通过CSS变量轻松解决。</p><div class="widget-codetool" style="display: none;">
      <div class="widget-codetool--inner">
                  <button type="button" class="btn btn-dark far fa-copy rounded-0 sflex-center copyCode" data-toggle="tooltip" data-placement="top" data-clipboard-text=".btn {
                      border: 2px solid var(--color, black);
                      }
                      .btn:hover {
                          background: var(--color, black);
                          }
                          .btn.red {
                              --color: red
                              }" title="" data-bs-original-title="复制" aria-label="复制"></button>
</div>
.btn {
    border: 2px solid var(--color, black);
    }
    .btn:hover {
        background: var(--color, black);
        }
        .btn.red {
            --color: red
            }

动手试试:codesandbox.io/s/yp29qoyvy…

示例3-使某些属性易于阅读

如果我们想为更复杂的属性值创建快捷方式,那么CSS 变量非常有用,这样我们就不必记住它了。

CSS属性,如box-shadowtransformfont或其他具有多个参数的CSS规则就是很好的例子。

我们可以将属性放在一个变量中,这样我们就可以通过更易于阅读的格式重用它。

// 主要代码
          :root {
            --tiny-shadow: 4px 4px 2px 0 rgba(0, 0, 0, 0.8);
              --animate-right: translateX(20px);
              }
              li {
                box-shadow: var(--tiny-shadow);
                }
                li:hover {
                  transform: var(--animate-right);
                  }
                  

动手试试:codesandbox.io/s/q3ww1znxn…

示例4-级联变量

标准级联规则也适用于CSS变量。如果一个自定义属性被声明多次,css文件中最下面的定义将覆盖它上面的定义。

下面的示例演示了在用户操作上动态操作属性是多么容易,同时也保持代码的清晰和简洁。

                            .container:hover {
                              --main-text: 18px;
                              }
                              " title="" data-bs-original-title="复制" aria-label="复制"></button>
</div>
      </div><pre class="hljs language-css">// 主要代码
      <span class="hljs-selector-class">.orange-container</span> {
        <span class="hljs-attr">--main-text</span>: <span class="hljs-number">18px</span>;
        }
        <span class="hljs-selector-class">.orange-container</span><span class="hljs-selector-pseudo">:hover</span> {
          <span class="hljs-attr">--main-text</span>: <span class="hljs-number">22px</span>;
          }
          <span class="hljs-selector-class">.red-container</span><span class="hljs-selector-pseudo">:hover</span> {
            <span class="hljs-attr">--main-text</span>: <span class="hljs-number">26px</span>;
            }
            <span class="hljs-selector-class">.title</span> {
              <span class="hljs-attribute">font-size</span>: <span class="hljs-built_in">var</span>(--title-text);
              }
              <span class="hljs-selector-class">.content</span> {
                <span class="hljs-attribute">font-size</span>: <span class="hljs-built_in">var</span>(--main-text);
                }
                
                <span class="hljs-selector-class">.container</span><span class="hljs-selector-pseudo">:hover</span> {
                  <span class="hljs-attr">--main-text</span>: <span class="hljs-number">18px</span>;
                  }
                  </pre><p></p><p>动手试试:<a href="https://link.segmentfault.com/?enc=eo97BD2u%2BXJmhxQQHCy2aQ%3D%3D.4KNYJWr1wWwPLqu4NQ22ATKMsNVwu79Er5sZwty%2BixOh3oy9hZXSC720MOcF7CU9d%2Fe34XUupHO4%2B%2FQWl1GgPQvYAg25pfw0WKaj%2BXZygsU%3D" rel="nofollow" target="_blank">https://codesandbox.io/s/xj0qxn2l7w?from-embed=&amp;file=/index.html</a></p><h4>示例5 -主题切换与CSS变量</h4><p>CSS变量的一大优点是它们的响应特性。 一旦我们更新它们,具有CSS变量值的任何属性也会被更新。 因此,仅需使用几行Javascript并巧妙地使用CSS变量,便可以创建主题切换器机制。</p><p></p><p>动手试试:<a href="https://link.segmentfault.com/?enc=FfX%2BaOj4Jm2ub4AxdLsu3w%3D%3D.FGNsCKfl9%2BgcQohlHnOacNbP0t0gByftIQhlsFU7wK9uzTMSvjuUX1QjeWQalkAEhl7oqYdF2JWCaPztrjOV8GLO1soWd7vAl%2BOi7Q2czE0%3D" rel="nofollow" target="_blank">https://codesandbox.io/s/24j4m8y5kn?from-embed=&amp;file=/scripts.js</a></p><h3 id="item-0-7">扩展</h3><p>就像CSS中几乎所有东西一样,变量也非常简单易用。 以下是一些未包含在示例中的技巧,但在某些情况下仍然非常有用:</p><p>注意大写,CSS变量区分大小写</p><div class="widget-codetool" style="display: none;">
      <div class="widget-codetool--inner">
                  <button type="button" class="btn btn-dark far fa-copy rounded-0 sflex-center copyCode" data-toggle="tooltip" data-placement="top" data-clipboard-text=":root {
                   --color: blue;
                    --COLOR: red;
                    }
                    /*--color and --COLOR are two different variables*/" title="" data-bs-original-title="复制" aria-label="复制"></button>
</div>
:root {
 --color: blue;
  --COLOR: red;
  }
  /*--color and --COLOR are two different variables*/

当我们使用var()函数时,还可以传入第二个参数。 如果找不到自定义属性,则将使用此值:

width: var(--custom-width, 33%);

可以将CSS变量直接用于HTML

<!--HTML-->
<html style="--size: 600px">
body {
  max-width: var(--size)
  }

可以在其他CSS变量中使用CSS变量:

--base-red-color: #f00;
--background-gradient: linear-gradient(to top, var(--base-red-color), #222);

可以通过媒体查询将CSS变量作为条件。 例如,以下代码根据屏幕大小更改 padding 的值:

                      @media screen and (min-width: 750px) {
                          --padding: 30px
                          }" title="" data-bs-original-title="复制" aria-label="复制"></button>
</div>
:root {
    --padding: 15px 
    }
<span class="hljs-keyword">@media</span> screen <span class="hljs-keyword">and</span> (<span class="hljs-attribute">min-width</span>: <span class="hljs-number">750px</span>) {
    <span class="hljs-attr">--padding</span>: <span class="hljs-number">30px</span>
    }</pre><p><code>calc()</code>函数中也可以使用CSS变量。</p><div class="widget-codetool" style="display: none;">
      <div class="widget-codetool--inner">
                  <button type="button" class="btn btn-dark far fa-copy rounded-0 sflex-center copyCode" data-toggle="tooltip" data-placement="top" data-clipboard-text="--text-input-width: 5000px;
                  max-width: calc(var(--text-input-width) / 2);" title="" data-bs-original-title="复制" aria-label="复制"></button>
</div>
      </div><pre class="hljs language-arduino">--text-input-width: <span class="hljs-number">5000</span>px;
      max-width: <span class="hljs-built_in">calc</span>(<span class="hljs-built_in">var</span>(--text-input-width) / <span class="hljs-number">2</span>);</pre><p>CSS 变量不是灵丹妙药。 它们不会解决我们在CSS领域中遇到的所有问题。 但是,它可以让我们的代码更具可读性和可维护性。</p><p>而且,它们极大地提高了跨大型文档进行更改的便利性。 只需将所有常量设置在一个单独的文件中,当我们只想对变量进行更改时,就不必跳过数千行代码。</p><p>~完,我是小智,Spa去了,记得点个赞支持一下油。</p><hr><p><strong>代码部署后可能存在的BUG没法实时知道,事后为了解决这些BUG,花了大量的时间进行log 调试,这边顺便给大家推荐一个好用的BUG监控工具 <a href="https://link.segmentfault.com/?enc=%2FPpYWkpBvSCkB8r6UFX9wQ%3D%3D.x1rq6mTo4kw2mQ%2BLzEzcQfE7CAEuoKuyZLgFalZnXmDF07nWPMpolqiZMnjBamDt" rel="nofollow" target="_blank">Fundebug</a></strong></p><p>原文:<a href="https://link.segmentfault.com/?enc=o0Qtfu%2FMFX4BeFhqbPwe%2Bg%3D%3D.vbldiEChSJSFvLXEuc4t4UBCGrWUjUvunScQIMIxKxyrVYOGoLUsXsD6ZCMmaPd31yAEer2FAyJ6bqvb4tfgO7sQsfNA6dOsC89LbjI58EA%3D" rel="nofollow" target="_blank">http://www.js-craft.io/blog/17-3-examples-of-using-css-variab...</a></p><h3 id="item-0-8">交流</h3><blockquote><p>有梦想,有干货,微信搜索 <strong>【大迁世界】</strong> 关注这个在凌晨还在刷碗的刷碗智。</p><p>本文 GitHub  <a href="https://link.segmentfault.com/?enc=z8wZYQZbSX9KmqIA%2FiVK3g%3D%3D.H8EYYma5NFRNcFCFmvfEkHslivdrQc52FKHH6aB%2FAWYlewIMVMLbN8E%2Bhnp7p%2Br%2B" rel="nofollow" target="_blank">https://github.com/qq449245884/xiaozhi</a> 已收录,有一线大厂面试完整考点、资料以及我的系列文章。</p></blockquote><p></p>