用5个示例理解 CSS 变量

做者:Daniel
译者:前端小智
来源:stackabuse

有梦想,有干货,微信搜索 【大迁世界】 关注这个在凌晨还在刷碗的刷碗智。css

本文 GitHub https://github.com/qq449245884/xiaozhi 已收录,有一线大厂面试完整考点、资料以及个人系列文章。html

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

在纯CSS支持变量以前,咱们有像Less和Sass这样的预处理程序。可是它们须要在使用前进行编译,所以(有时)增长了一层额外的复杂性。git

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

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

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 上。函数

image.png

如今,让咱们看看这些CSS变量的实际做用。工具

示例1-管理颜色

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

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

image.png

动手试试:https://codesandbox.io/s/8kky...

示例2-删除重复的代码

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

.btn {
  border: 2px solid black;
  // more props here
}

.btn:hover {
  background: black;
  // more props here
}

.btn.red {
  border-color: red
}
.btn.red:hover {
  background: red
}

像这样使用它们:

<button class="btn">Hello</button>
<button class="btn red">Hello</button>

可是,这会增长一些代码重复。在.red类中,咱们必须将边框颜色和背景都设置为红色。万一哪天须要更改颜色,那就很麻烦了,须要一个一个的改。这个问题能够经过CSS变量轻松解决。

.btn {
    border: 2px solid var(--color, black);
}
.btn:hover {
    background: var(--color, black);
}
.btn.red {
    --color: red
}

image.png

动手试试:https://codesandbox.io/s/yp29...

示例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);
}

动手试试:https://codesandbox.io/s/q3ww...

image.png

示例4-级联变量

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

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

// 主要代码
.orange-container {
  --main-text: 18px;
}
.orange-container:hover {
  --main-text: 22px;
}
.red-container:hover {
  --main-text: 26px;
}
.title {
  font-size: var(--title-text);
}
.content {
  font-size: var(--main-text);
}

.container:hover {
  --main-text: 18px;
}

动手试试:https://codesandbox.io/s/xj0q...

示例5 -主题切换与CSS变量

CSS变量的一大优势是它们的响应特性。 一旦咱们更新它们,具备CSS变量值的任何属性也会被更新。 所以,仅需使用几行Javascript并巧妙地使用CSS变量,即可以建立主题切换器机制。

动手试试:https://codesandbox.io/s/24j4...

扩展

就像CSS中几乎全部东西同样,变量也很是简单易用。 如下是一些未包含在示例中的技巧,但在某些状况下仍然很是有用:

注意大写,CSS变量区分大小写

: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 的值:

:root {
    --padding: 15px 
}

@media screen and (min-width: 750px) {
    --padding: 30px
}

calc()函数中也可使用CSS变量。

--text-input-width: 5000px;
max-width: calc(var(--text-input-width) / 2);

CSS 变量不是灵丹妙药。 它们不会解决咱们在CSS领域中遇到的全部问题。 可是,它可让咱们的代码更具可读性和可维护性。

并且,它们极大地提升了跨大型文档进行更改的便利性。 只需将全部常量设置在一个单独的文件中,当咱们只想对变量进行更改时,就没必要跳过数千行代码。

~完,我是小智,Spa去了,记得点个赞支持一下油。


代码部署后可能存在的BUG无法实时知道,过后为了解决这些BUG,花了大量的时间进行log 调试,这边顺便给你们推荐一个好用的BUG监控工具 Fundebug

原文:http://www.js-craft.io/blog/1...

交流

有梦想,有干货,微信搜索 【大迁世界】 关注这个在凌晨还在刷碗的刷碗智。

本文 GitHub https://github.com/qq44924588... 已收录,有一线大厂面试完整考点、资料以及个人系列文章。

相关文章
相关标签/搜索