石家庄

点击搜索

发布

【转译】介绍CSS变量

区域:
石家庄 > 裕华 > 裕兴
类别:
网站制作
地址:
翟营大街空中花园
  CSS是现在网站建设一种语言,也是现在为常用的建站方式。在CSS中存在真很多变量,这些变量可以让建设网站更加便捷。CSS变量给我们很多相同的优势,经典的变量提供了编程语言:方便、代码可重用性、更可读的代码库、提高预防错误措施。

  例如:

  :root {
      base-font-size: 16px;
      link-color: #6495ed;
      }
  p {
    font-size: var( --base-font-size );
    }
  a {
    font-size: var( --base-font-size );
    color: var( --link-color );
    }

  ,基础知识。

  CSS有三个主要组件时,你应该知道使用CSS变量:

  1、自定义属性

  2、var()Functİon

  3、:root伪类

  4、自定义属性

  我们已经知道这个标准类的CSS属性包含了color、 margin、width以及font-size。那么下面的例子使用了colorCSS属性:

  body {color: #000000; /* The "color" CSS property */}

  自定义属性只是意味着我们作者定义属性的名字,定义一个自定义属性名称,我们需要用两个破折号(前缀--)。如果我们想要创建一个自定义属性的名称text-color有黑色的颜色值(#000000十六进制代码),这就是我们可以做的:

  :root {--text-color: #000000; /* A custom property named "text-color" */}

  var()函数,为了让我们的自定义属性应用于我们的工作,我们必须使用 var()Functİon,否则浏览器不会知道他们的存在。如果我们想使用这些,我们就会知道其价值--text-color自定义属性在我们 p、 h1、 h2这样式规则,然后我们需要使用 var()函数如下:

  :root { --text-color: #000000; }
  p {
    color: var( --text-color );
    font-size: 16px;
    }
  h1 {
    color: var( --text-color );
    font-size: 42px;
    }
  h2 {
    color: var( --text-color );
    font-size: 36px;
    }

  上面的例子是相当于:

  p {
    color: #000000;
    font-size: 16px;
    }
  h1 {
    color: #000000;
    font-size: 42px;
    }
  h2 {
    color: #000000;
    font-size: 36px;
    }

  :root伪类,我们需要一个地方来把我们的自定义属性。我们可以指定自定义属性在任何样式规则,但很多时候不是一个好主意,因为指定自定义属性到处是礼物可维护性和CSS-readability挑战。:root伪类代表了的HTML文档。这把我们的自定义属性选择器是一个很好的地方,因为我们可以通过这些预见覆盖自定义属性值其他更有特异性的CSS选择器。

  CSS变量的好处,可维护性。在这给定web开发项目中,我们常常会重用特定CSS属性值。我们会经常重用colors,line heights,margins,font sizes等变量值。

  这里有四个样式规则的一个例子可能会受益于CSS变量:

  h1 {
    margin-bottom: 20px;
    font-size: 42px;
    line-height: 120%;
    color: gray;
    }
  p {
    margin-bottom: 20px;
    font-size: 18px;
    line-height: 120%;
    color: gray;
    }
  img {
      margin-bottom: 20px;
      border: 1px solid gray;
      }
  .callout {
        margin-bottom: 20px;
        border: 3px solid gray;
        border-radius: 5px;
        }

  问题表面这就当我们需要改变某些属性值。如果我们手动更改这个值,它可能需要我们大量的时间,还有一个巨大的机会我们将这个错误地方,尤其是我们的样式表是巨大的。同样的,如果我们执行一个批处理查找和替换,我们可能会无意中这就会影响其他样式规则。

  我们可以使用CSS变量改写上面的例子:

  :root {
      --base-bottom-margin: 20px;
      --base-line-height:   120%;
      --text-color:       gray;
      }
  h1 {
    margin-bottom: var( --base-bottom-margin );
    font-size: 42px;
    line-height: var( --base-line-height );
    color: var( --text-color );
    }
  p {
    margin-bottom: var( --base-bottom-margin );
    font-size: 18px;
    line-height: var( --base-line-height );
    color: var( --text-color );
    }
  img {
      margin-bottom: var( --base-bottom-margin );
      border: 1px solid gray;
      }
  .callout {
        margin-bottom: var( --base-bottom-margin );
        border: 1px solid gray;
        border-radius: 5px;
        color: var( --text-color );
        }

  现在想象一下你的客户说你屏幕上的文字是难以阅读,因为文本的颜色太轻了。在这种情况下,我们只需要更新在我们的CSS这一行:--text-color: black;

  这-66%少一行代码编辑,在以前的样式规则集的上下文中一行与行。同样,使用CSS变量让我们更容易,当我们想与我们的实验设计。当我们开发这个项目,我们可以快速测试的颜色值、目的和底部边距值都在一个地方,我们可以看到整体的影响。

  CSS改善可读性,自定义属性可以帮助使我们的样式表达易于阅读,它可以使我们的CSS属性声明更有意义。比较:

  background-color: yellow;
  font-size: 18px;

  相对于这个:

  background-color: var( --highlight-color );
  font-size: var( --base-font-size );

  定义属性的名字--base-font-size和--highlight-color甚至当我们阅读别人的代码时,我们立刻知道属性值在做什么。要记住的事情和大小写敏感,自定义属性区分大小写(与常规CSS属性)。

  :root {
      --main-bg-color: green;
      --MAIN-BG-COLOR: RED;
      }
  .box {background-color: var( --main-bg-color ); /* green background */}
  .circle {
        BACKGROUND-COLOR: VAR(--MAIN-BG-COLOR ); /* red background */
        border-radius: 9999em;
        }

  .box,
  .circle {
        height: 100px;
        width: 100px;
        margin-top: 25px;
        box-sizing: padding-box;
        padding-top: 40px;
        text-align: center;
        }
  在上面的例子中,实际上有两个已定义的自定义属性:--main-bg-color和--MAIN-BG-COLOR。

  自定义属性值的决议,当一个自定义属性被声明为不止一次分配遵循正常的CSS层叠和继承规则。在下面的示例中,该链接将被指派的颜色red因为.container选择器相比有更高的特异性:root和 body。

  html
  <body>
  <div class="container">
  <a href="">Link</a>
  </div>
  </body>

  CSS

  :root {--highlight-color: yellow;}
  body {--highlight-color: green;}
  .container {--highlight-color: red;}
  a {color: var( --highlight-color );}

  然而,如果我们删除.container从我们的代码样式规则,链接将被指派的颜色green因为body成为下一个选择器匹配我们的链接。

  回退值,你可以分配一个后备属性值时使用var()函数表示法。简单地提供后备属性值作为一个额外的参数用逗号划(,)。在以下示例中,.box元素应该是呈现黑色背景。然而,由于有一个错误引用自定义属性的名字时,使用这个呈现背景将这个回退值(即red)。

  html
  <div class="box">A Box</div>

  CSS
  div { --container-bg-color: black;}
  .box {
      width: 100px;
      height: 100px;
      padding-top: 40px;
      box-sizing: padding-box;
      background-color: var( --container-bf-color, red );
      color: white;
      text-align: center;
      }

  避免这种情况的一个好方法就是想出描述性定义属性的名称。例如,命名上面的自定义属性--small-button-width使其不当使用不太可能。

  (转载请注明转自:ww***zha***.cn/news/n1643.htm,谢谢!珍惜别人的劳动成果,就是在尊重自己!)
查看更多石家庄网站/软件服务信息

免责声明:此信息系发布者(UID:167270)自行发布,本站是服务平台,仅提供信息存储空间服务,该信息内容的真实性及合法性由该发布者完全负责。

© lieju.com 联系我们