专业游戏门户,分享手游网游单机游戏百科知识攻略!

嗨游网
嗨游网

什么是CSS变量?CSS变量的学习:CSS变量的继承&作用域

来源:小嗨整编  作者:小嗨  发布时间:2024-03-20 08:06
摘要:CSS变量能帮助我们干什么在一些命令式编程语言中,像Java、C++亦或是JavaScript,通过变量我们能够跟踪某些状态。变量是一种符号,关联着一个特定的值,变量的值能随着时间的推移而改变。在像CSS这种声明式语言中,随着时间而改变的值...

CSS变量能帮助我们干什么

在一些命令式编程语言中,像Java、C++亦或是JavaScript,通过变量我们能够跟踪某些状态。变量是一种符号,关联着一个特定的值,变量的值能随着时间的推移而改变。在像CSS这种声明式语言中,随着时间而改变的值并不存在,也就没有所谓变量的概念了。CSS 引入了一种层级变量的概念,从而能够从容应对可维护性的挑战。这就会使得在整个 CSS tree 中都可以象征性的引用一个变量

一、什么是CSS变量

css 变量当前有两种形式:

什么是CSS变量?CSS变量的学习:CSS变量的继承&作用域

变量,就是拥有合法标识符和合法的值。可以被使用在任意的地方。可以使用var()函数使用变量。例如:var(--example-variable)会返回--example-variable所对应的值自定义属性。这些属性使用--where的特殊格式作为名字。例如--example-variable: 20px;即使一个css声明语句。意思是将20px赋值给--example-varibale变量

二、变量的声明

变量的命名

变量声明使用两根连词线--表示变量,$color是属于Sass的语法,@color是属于Less的语法,为避免冲突css原生变量使用--)注意: 变量名大小写敏感,--header-color--Header-Color是两个不同变量

声明方式

CSS变量声明的方式非常简单,如下,声明了一个名叫color的CSS变量。

在css文件中写

写在html标签的inline-style里

用JS给某个元素声明,方法.style.setProperty

body{  --color: red;}document.getElementsByTagName('body')[0].style.setProperty('--color', 'red')
登录后复制
变量值的类型

如果变量值是一个字符串,可以与其他字符串拼接

--bar: 'hello';--foo: var(--bar)' world';body:after {  content: '--screen-category : 'var(--screen-category);}
登录后复制

如果变量值是数值,不能与数值单位直接连用,必须使用calc()函数,将它们连接

.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);
登录后复制

注意: 变量值只能用作属性值,不能用作属性名

.foo {  --side: margin-top;  /* 无效 */  var(--side): 20px;}
登录后复制

上面代码中,变量--side用作属性名,这是无效的

三、CSS变量的继承&作用域

自定义属性同样支持继承。一个元素上没有定义自定义属性,该自定义属性的值会继承其父元素

class="one">  

登录后复制

定义下面的CSS:

.two { --test: 10px; }.three { --test: 2em; }
登录后复制

在这个例子中,var(--test)的结果是:

对应的节点: 10px

对应的节点: element: 2em

对应的节点: 10px (inherited from its parent)

对应的节点: 无效值, 即此属性值为未被自定义css变量覆盖的默认值

最顶层的作用域就是:root

四、响应式

p {  --color: #7F583F;  --bg: #F7EFD2;}.mediabox {  color: var(--color);  background: var(--bg);}@media screen and (min-width: 768px) {  body {    --color:  #F7EFD2;    --bg: #7F583F;  }}
登录后复制

五、与预处理器的不同

1、预处理器变量不是实时的

$color:#7F583F;@media screen and (min-width: 768px) {    $color: #F7EFD2;}.mediabox {      background: $color;}
登录后复制

编译结果

.mediabox {  background: #7F583F; }
登录后复制

2、预处理器不能限定作用域

$zcolor:blue;.ulbox {    $zcolor:red;}ul{    color: $zcolor;}
登录后复制

编译为

ul {  color: blue; }
登录后复制

3、预处理器变量不可互操作

原生的CSS自定义属性可以与任何CSS预处理器或纯CSS文件一起使用

六、JS操作变量

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 */}// Jsif (window.CSS && window.CSS.supports && window.CSS.supports('--a', 0)) {    alert('CSS properties are supported');} else {    alert('CSS properties are NOT supported');}
登录后复制总结

相较于传统的 LESS 、SASS 等预处理器变量,CSS 变量的优点在于:

CSS 变量的动态性,能在页面运行时更改,而传统预处理器变量编译后无法更改

CSS 变量能够继承,能够组合使用,具有作用域

配合 Javascript 使用,可以方便的从 JS 中读/写

相关文章:

PHP的学习--可变变量,--可变变量

php 学习日志- 变量作用域,变量

相关视频:

极客学院CSS及CSS3视频教程

以上就是什么是CSS变量?CSS变量的学习:CSS变量的继承&作用域的详细内容,更多请关注易企推科技其它相关文章!


本文地址:网络百科频道 https://www.eeeoo.cn/wangluo/1151434.html,嗨游网一个专业手游免费下载攻略知识分享平台,本站部分内容来自网络分享,不对内容负责,如有涉及到您的权益,请联系我们删除,谢谢!


网络百科
小编:小嗨整编
相关文章相关阅读
  • 阴阳师辉夜姬带什么御魂(阴阳师辉夜姬值得养吗)?

    阴阳师辉夜姬带什么御魂(阴阳师辉夜姬值得养吗)?

    阴阳师辉夜姬带什么御魂(阴阳师辉夜姬值得养吗)?辉夜姬作为阴阳师中的一位强力辅助式神,凭借其独特的技能和强大的辅助能力,成为了许多玩家心仪的选择。那么辉夜姬究竟带什么御魂才能发挥最大潜力呢?本文将为您详细介绍辉夜姬的御魂搭配,并分析其值得养...

  • 阴阳师青行灯什么时候出的(阴阳师青行灯值得培养吗)?

    阴阳师青行灯什么时候出的(阴阳师青行灯值得培养吗)?

    阴阳师青行灯什么时候出的(阴阳师青行灯值得培养吗)?随着阴阳师这款手游的火热,各种式神层出不穷,其中SSR级别的式神更是备受玩家关注。青行灯作为SSR中的常青树,自出道以来便以其独特的技能和强大的实力,吸引了无数玩家的目光。阴阳师青行灯什么...

  • 阴阳师彼岸花什么时候出的(阴阳师彼岸花值得练吗)?

    阴阳师彼岸花什么时候出的(阴阳师彼岸花值得练吗)?

    阴阳师彼岸花什么时候出的(阴阳师彼岸花值得练吗)?彼岸花作为阴阳师中的SSR式神,首次出现在游戏中是在2016年。随后,官方推出了SP版本的彼岸花,名为“夜溟彼岸花”,并于2021年1月6日正式上线。阴阳师彼岸花值得练吗彼岸花的技能设计非常...

  • 魔兽世界泰兰德是什么职业(魔兽世界泰兰德幻化怎么获得)?

    魔兽世界泰兰德是什么职业(魔兽世界泰兰德幻化怎么获得)?

    魔兽世界泰兰德是什么职业(魔兽世界泰兰德幻化怎么获得)?在魔兽世界中,泰兰德是魔兽世界中暗夜精灵种族的代表性角色,她以牧师职业为主。牧师在游戏中拥有强大的治疗和辅助能力,是团队中不可或缺的重要角色。泰兰德作为一名牧师,擅长使用圣光和暗影之力...

  • lol小丑的名字叫什么(lol小丑怎么分辨真假)?

    lol小丑的名字叫什么(lol小丑怎么分辨真假)?

    lol小丑的名字叫什么(lol小丑怎么分辨真假)?在lol英雄联盟中,小丑(Janna)作为一位辅助英雄,以其独特的技能和出色的辅助能力深受玩家喜爱。然而,许多玩家在游戏中可能遇到真假小丑难以辨别的问题。本文将为大家详细解析LOL小丑的名字...

  • lol老鼠叫什么(lol老鼠技能介绍)?

    lol老鼠叫什么(lol老鼠技能介绍)?

    lol老鼠叫什么(lol老鼠技能介绍)?在lol中,老鼠这位英雄正式名称为“瘟疫之源·图奇”。他以其独特的毒液技能和隐身能力,在游戏中扮演着一名出色的刺客和骚扰者。以下是关于老鼠的详细技能介绍:lol老鼠技能介绍一、被动技能——死亡毒液老鼠...

  • dnf红玉髓是干什么用的(dnf红玉髓在哪里兑换)?

    dnf红玉髓是干什么用的(dnf红玉髓在哪里兑换)?

    dnf红玉髓是干什么用的(dnf红玉髓在哪里兑换)?在dnf中,红玉髓是一种非常有用的材料,它不仅能够兑换圣物装备,还能换取各种药剂,对于玩家来说,掌握红玉髓的用途和兑换地点至关重要。dnf红玉髓是干什么用的1.兑换圣物装备:红玉髓是制作圣...

  • 闲鱼app什么时候上线的(闲鱼app官网)?

    闲鱼app什么时候上线的(闲鱼app官网)?

    闲鱼app什么时候上线的(闲鱼app官网)?闲鱼App,原名为“闲鱼二手交易”,作为阿里巴巴集团旗下的知名二手交易平台,自上线以来,受到了广大用户的喜爱。本文将揭秘闲鱼App的上线时间,带您了解闲鱼官网的起源与发展。闲鱼app上线于2015...

  • 周排行
  • 月排行
  • 年排行

精彩推荐