在一些命令式编程语言中,像Java、C++亦或是JavaScript,经过变量咱们可以跟踪某些状态。变量是一种符号,关联着一个特定的值,变量的值能随着时间的推移而改变。
在像CSS这种声明式语言中,随着时间而改变的值并不存在,也就没有所谓变量的概念了。
CSS 引入了一种层级变量的概念,从而可以从容应对可维护性的挑战。这就会使得在整个 CSS tree 中均可以象征性的引用一个变量
CSS 变量当前有两种形式:css
变量,就是拥有合法标识符和合法的值。能够被使用在任意的地方。可使用var()函数使用变量。例如:var(--example-variable)会返回--example-variable所对应的值
自定义属性。这些属性使用--where的特殊格式做为名字。例如--example-variable: 20px;即便一个css声明语句。意思是将20px赋值给--example-varibale变量html
变量声明使用两根连词线--表示变量,$color是属于Sass的语法,@color是属于Less的语法,为避免冲突css原生变量使用--)
注意: 变量名大小写敏感,--header-color
和--Header-Color
是两个不一样变量编程
CSS变量声明的方式很是简单,以下,声明了一个名叫color的CSS变量。浏览器
body{ --color: red; } <body style="--color: red;"></body> document.getElementsByTagName('body')[0].style.setProperty('--color', 'red')
若是变量值是一个字符串,能够与其余字符串拼接编程语言
--bar: 'hello'; --foo: var(--bar)' world'; body:after { content: '--screen-category : 'var(--screen-category); }
若是变量值是数值,不能与数值单位直接连用,必须使用calc()函数,将它们链接ide
.foo { --gap: 20; /* 无效 */ margin-top: var(--gap)px; } .foo { --gap: 20; margin-top: calc(var(--gap) * 1px); }
若是变量值带有单位,就不能写成字符串函数
/* 无效 */ .foo { --foo: '20px'; font-size: var(--foo); } /* 有效 */ .foo { --foo: 20px; font-size: var(--foo);
注意: 变量值只能用做属性值,不能用做属性名code
.foo { --side: margin-top; /* 无效 */ var(--side): 20px; }
上面代码中,变量--side用做属性名,这是无效的htm
自定义属性一样支持继承。一个元素上没有定义自定义属性,该自定义属性的值会继承其父元素blog
class="one"> <div class="two"> <div class="three"> </div> <div class="four"> </div> <div> </div>
定义下面的CSS:
.two { --test: 10px; } .three { --test: 2em; }
在这个例子中,var(--test)的结果是:
最顶层的做用域就是:root
div { --color: #7F583F; --bg: #F7EFD2; } .mediabox { color: var(--color); background: var(--bg); } @media screen and (min-width: 768px) { body { --color: #F7EFD2; --bg: #7F583F; } }
一、预处理器变量不是实时的
$color:#7F583F; @media screen and (min-width: 768px) { $color: #F7EFD2; } .mediabox { background: $color; }
编译结果
.mediabox { background: #7F583F; }
二、预处理器不能限定做用域
$zcolor:blue; .ulbox { $zcolor:red; } ul{ color: $zcolor; }
编译为
ul { color: blue; }
三、预处理器变量不可互操做
原生的CSS自定义属性能够与任何CSS预处理器或纯CSS文件一块儿使用
CSS 变量能够和 JS 互相交互
:root{ --testMargin:70px; } // 读取 var root = getComputedStyle(document.documentElement); var cssVariable1 = root.getPropertyValue('--testMargin').trim(); console.log(cssVariable1); // '70px' // 写入 document.documentElement.style.setProperty('--testMargin', '100px'); var cssVariable2 = root.getPropertyValue('--testMargin').trim(); console.log(cssVariable2); // '100px' // 删除 document.documentElement.style.removeProperty('--testMargin'); var cssVariable3 = root.getPropertyValue('--testMargin').trim(); console.log(cssVariable3); // '70px'
检测浏览器是否支持CSS自定义属性的方法
/*css*/ @supports ( (--a: 0)) { /* supported */ } @supports ( not (--a: 0)) { /* not supported */ } // Js if (window.CSS && window.CSS.supports && window.CSS.supports('--a', 0)) { alert('CSS properties are supported'); } else { alert('CSS properties are NOT supported'); }
https://caniuse.com/#search=c...
相较于传统的 LESS 、SASS 等预处理器变量,CSS 变量的优势在于: