资讯专栏INFORMATION COLUMN

在原生CSS中使用变量

FreeZinG / 1326人阅读

摘要:而现在,我们可以在原生中使用变量了先来两个在线感受一下定义变量,也称为自定义属性。但是局部变量只能够在被申明的元素及其子元素中使用。在中使用变量变量是的一部分,这意味着我们可以通过来访问修改变量的值,这是等预处理器所做不到的。

本文首发于我的博客

一直以来,CSS作为一种申明式的样式标记语言,很难像如javascript等命令式编程语言一样通过定义和使用变量的方式来维护和追踪某些状态。后来随着scss,less等CSS预处理器的出现,我们可以像优秀的开源框架bootstrap那样,通过维护一个_variables.scss变量文件的方式来维护一个庞大的项目。但预处理需要编译,并非CSS原生支持。而现在,我们可以在原生CSS中使用变量了

先来两个在线demo感受一下:

demo1

demo2

定义
CSS变量,也称为CSS自定义属性。通过以--开头的自定义属性来设置变量名,存储一些特定值,在需要的地方使用 var() 来访问。如:
p {
  --primary-color: #6bc30d;
  color: var(--primary-color);
}
如何申明变量

可以像定义任何css属性一样来申明变量,不同的是,变量名必须以--开头。如 --primary-color: #6bc30d

如何使用变量

而要使用一个变量的值,需要使用 var() 函数,并将变量的名称作为参数传入。 如 color: var(--primary-color);

var()函数
var()函数可以代替元素中任何属性中的值的任何部分。

var() 函数接受两个参数,参数一是要替换的自定义属性的名称,参数二是可选的,作为参数一无效时候的回退值(如果第一个参数引用的自定义属性无效,则该函数将使用第二个值)。

var(  [,  ]? )
/* 自定义属性名*/
/* 声明值(回退值)*/
使用变量的意义

无需多次定义,同样的属性可以重复使用

让CSS文件可读易维护(如主题样式,只需修改一个变量即可,而不再是枯燥的查找替换),灵活性更高

注意点

变量名称必须以 -- 开头

变量只能存储一个属性的值,而不能用来存储一个属性,如下例子是错误的:

/*这样是错误的*/
p {
  --primary-color: color;
  var(--primary-color) : #6bc30d
}

变量中无法使用加减等数学方法,如果需要使用计算,则可以使用 calc 函数:

/*这样是错误的*/
p {
  --font-size : 20px * 2;
  font-size: var(--font-size);
}
/*这样是正确的*/
p {
  --font-size : calc(20px * 2);
  font-size: var(--font-size); /*40px*/
}
/*这样拼接也是无效的*/
p {
  --font-size: 20;
  font-size: var(--font-size)px; /*无效*/
}
/*这样是有效的:*/
p {
  --font-size: 20;
  font-size: calc(var(--font-size) * 1px); /*20px*/
}

CSS变量是区分大小写的

/*这是两个不同的变量*/
:root {
 --color: blue;
--COLOR: red;
}
scss等CSS预处理中变量的区别

CSS变量是浏览器原生支持的,不需要经过编译就可以使用

CSS变量是DOM的一部分,可以使用JS直接修改

作用域

虽然可以在css的任何地方定义变量,但是css变量也是有作用域的。CSS的变量作用域分为全局作用域和局部作用域。因此在申明一个变量之前,首先要确定这个变量要用在哪里?

全局变量

通过在:root中申明变量,就可以申明一个全局变量,可以在整个文档结构中使用这个变量,因为CSS变量是可继承的。

:root{
  --primay-color: #6bc30d;
}
/* 在任何地方都可以使用`:root`中定义的全局变量 */
p, div , a {
  color : var(--primay-color);
}
#myDiv, .myDiv {
  color : var(--primay-color);
}
局部变量

可以在除:root外的任何地方申明局部变量。但是局部变量只能够在被申明的元素及其子元素中使用。局部变量更多的应用在值覆盖上。

.modal {
  --modal-padding-top: 30px;
}
/*当前元素及其子元素中使用*/
.modal, 
.modal-content {
  padding-top: var(--modal-padding-top); /*30px*/;
}
/*在其他元素上无效*/
body {
  padding-top: var(--modal-padding-top); /*无效设置,使用默认值*/
}
变量的继承

与其他CSS属性一样,CSS中的变量也是可以继承的。

:root{
  --color: red;
}
P {
  --pColor: green;
  color: var(--color); /*red*/
}
p > span{
  color : var(-pColor); /*green*/
}

多个申明中变量的优先级

同名变量可以重复申明,这样变量就会有了优先级的问题,如下例子:

:root {
  --color: red;
}
div {
  --color: green;
}
#myDiv {
  --color: yellow; 
  --color: blue; 
}
* {
  color: var(--color);
}

我正常显示红色

我显示绿色
我显示蓝色

那么我呢?

如图,div中的局部变量覆盖了:root中设置的值,而特定ID的div元素#myDiv又覆盖了div中的值,最后作为#myDiv的子元素p继承了其父级的值,而不是使用root中申明的值

无效变量

对于变量来讲,CSS属性的有效性并不适用。对于变量这种自定义属性,即便在上下文环境中这个值是无意义的,但是都能够通过var()函数调用。无意义的变量值会导致无效的CSS申明。通过var()函数调用后会被解析为初始值。

:root {
  --color: 20px;
}
p {
  --font-size: green;
  background-color: var(--color); 
  /* background-color: 20px; 无效,将回退为transparent */
}
在html属性中使用css变量

就像其他CSS属性一样,在html中可以通过内联变量来设置变量的值,并且也能够正常工作



  

我使用内联变量值得方式来设置样式

在媒体查询中使用css变量

可以根据屏幕宽度的变化来改变变量的值,从而更容易的实现响应式布局。

:root {
  --font-size: 30px;
  --color: red;
}
html{
  color: var(--color);
  font-size: var(--font-size);
}

@media screen and (min-width: 480px) {
  :root {
    --font-size: 50px;
    --color: green;
  }
}
@media screen and (min-width: 760px) {
  :root {
    --font-size: 100px;
    --color: blue;
  }
}

在js中使用css变量

css变量是DOM的一部分,这意味着我们可以通过javascript来访问/修改css变量的值,这是scss等css预处理器所做不到的。
要用JavaScript来更新CSS变量,需要调用已声明变量元素上的style对象上的 setProperty 方法。

setProperty()
//语法
element.style.setProperty(propertyName, value, priority);
//propertyName 是一个 DOMString 被更改的CSS属性.
//value <可选> 是一个 DOMString 新的属性值. 如果没有指定, 则当作空字符.不能包含 "!important"
//priority <可选> 是一个 DOMString。允许 "important" CSS 优先被设置. 如果没有指定, 则当作空字符.

//在根元素(html)上更新变量值
document.documentElement.style.setProperty(propertyName, value)
示例
:root {
  --font-size: 20px;
  --background: red;
}
body {
  font-size: var(--font-size);
  background-color: var(--background);
  color: #fff;
}

使用JavaScript来改变背景色

参考文档

Using CSS custom properties (variables)

CSS Variables overview

Everything you need to know about CSS Variables

本文首发于我的博客

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/115735.html

相关文章

  • 原生css 变量使用

    摘要:函数还可以使用第二个参数,表示变量的默认值。注意,变量值只能用作属性值,不能用作属性名。如果变量值是数值,不能与数值单位直接连用。六兼容性处理对于不支持变量的浏览器,可以采用下面的写法。那些对无用的信息,也可以放入变量。前两天看到阮大神的一篇在css中使用变量的文章,整理了一下。 这个重要的 CSS 新功能,所有主要浏览器已经都支持了。本文全面介绍如何使用它,你会发现原生 CSS 从此变得异...

    番茄西红柿 评论0 收藏0
  • CSS基础篇--CSS/CSS3原生变量var详解

    摘要:但由于预处理器不在浏览器中运行并且无法看到标记,它们不能这样做。跨不同的工具集或上托管的第三方样式表共享预处理器变量是不可能或至少不容易的。原生的自定义属性可以与任何预处理器或纯文件一起使用。 使用语法 首先我们先来看一个例子:html代码: 这是一段文字 css代码: .element { width:200px; height:200px; --main-bg-colo...

    sanyang 评论0 收藏0
  • 原生css变量声明

    摘要:原生变量声明噫我为什么要用原生这个名词啊,管他呢。我发现了一个不得了的东西,接触前端都有一年多的时间了,今天才知道原生也可以变量声明这个黑科技啊。 原生css变量声明 噫~~~我为什么要用原生css这个名词啊,管他呢。我发现了一个不得了的东西,接触前端都有一年多的时间了,今天才知道原生css也可以变量声明这个黑科技啊。我是不是和时代脱轨太长时间了。好了,来吧,介绍一下这个东东。统计一下...

    Imfan 评论0 收藏0
  • Sass快速入门学习笔记

    摘要:在中,你可以像俄罗斯套娃那样在规则块中嵌套规则块。这个过程中,用了两步,每一步都是像打开俄罗斯套娃那样把里边的嵌套规则块一个个打开。与此类似,会命中元素和类名为的元素。这种选择器称为群组选择器。1. 使用变量; sass让人们受益的一个重要特性就是它为css引入了变量。你可以把反复使用的css属性值 定义成变量,然后通过变量名来引用它们,而无需重复书写这一属性值。或者,对于仅使用过一 次的属...

    appetizerio 评论0 收藏0
  • 「翻译」逐步替换Sass

    摘要:本文来自心谭博客译文逐步替换,最新文章请见导航页,欢迎交流翻译说明这是一篇介绍现代核心特性的文章,并且借助进行横向对比,充分体现了作为一门设计语言的快速发展以及新特性为我们开发者带来的强大生产力。 本文来自心谭博客·「译文」逐步替换Sass,最新文章请见导航页,欢迎交流✿✿ヽ(°▽°)ノ✿ 翻译说明 这是一篇介绍现代 css 核心特性的文章,并且借助 sass 进行横向对比,充分体现了...

    explorer_ddf 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<