介绍一种CSS变量未定义语法也OK的小妙招

更新日期: 2022-06-12阅读: 1.1k标签: 变量

一、先看案例

在《css世界》P30 页那里有介绍过一个 transform 动画和 transform 定位冲突的场景,如下图所示:


用一句话描述就是:

弹框等居中定位元素如果使用 transform:translate(-50%,50%) 偏移实现,则定位元素的显示动画如果包含 transform 变化,则会发生冲突,使定位失效。

我书中提出的解决方案是宽高设置为 fit-content ,这样就可以使用 inset:0 + margin:auto 实现不影响 transform 动画的居中对齐效果了。

除了使用兼容性好不太好的 translate,scale,rotate属性进行分离设置外,最近我发现,其实还有一种更另类的巧妙方法可以处理此问题。

那就是逗号后面留空的 CSS 自定义属性语法,例如:

transform: var(--transform, ) scale(1);

二、深入CSS变量缺省值

CSS变量浏览器还没有怎么支持的时候(2016年)我就率先研究与介绍过了,见此文“了解CSS变量var”,里面介绍了很多CSS变量的细节知识。

然而,学无止境,我以为了解了全部,实际上还是有知识的盲区。

下面这个基础特性相信大家都知道。

即 CSS 变量是支持缺省值的,也就是当 CSS 自定义属性没有定义的时候使用的值,例如下面的用法示意:

color: var(--color, skyblue);

如果 --color 未定义,我们就使用 skyblue 作为颜色值。

但是,怕是很多人并不知道,后面的那个默认兜底的缺省值是可以不写的,注意,是不写,不是没有这个参数,参数还在,表现出来的效果就是括号内有个光秃秃的逗号,就像下面这样:

color: var(--color, );

这是什么意思呢?

就是如果 --color 未定义,则此变量当作没存在,未设置。

注意,这个语法和下面的语法区别巨大,不是同一个东西。

color: var(--color);

我们看一个例子就知道区别在哪里了,有如下的 html 和 CSS:

<p class="zhang">颜色是?</p>
<p class="xinxu">颜色是?</p>
.zhang {
  color: deeppink var(--color, );
}
.xinxu {
  color: deeppink var(--color);
}

此时,.zhang 类名对应的 <p> 元素的颜色和 .xinxu 类名对应的 <p> 元素是不一样的,实际渲染效果如下截图所示(实时渲染,桌面浏览器可以打开控制台查看源码):

颜色是?

颜色是?

可以看到,上面一行文字的颜色是深粉色,而下面一行的文字颜色是黑色。

原因在于当 --color 未定义的时候, deeppink var(--color, ) 等同于 deeppink ,因此颜色是深粉色,而 deeppink var(--color) 可以看成是 deeppink undefined ,语法无效,于是使用继承的黑色。

三、在多值CSS属性中的应用

对于单值 CSS 属性,空白缺省值的价值并不是很明显,因为使用或者不使用区别并不是很大。

例如:

div {
    border-radius: var(--radius, );
}

div {
    border-radius: var(--radius);
}

的渲染表现都是一致的。

但是在多值 CSS 属性中,情况就完全不同了。

回到一开始的 transform 冲突的场景这里,如果我们的 transform 动画这么设置,那么就能很大程度上避免 transform 属性使用冲突的问题了。

@keyframes scaleIn {
    from {
        transform: var(--transform, ) scale(0.1);
    }
    to {
        transform: var(--transform, ) scale(1);
    }
}

此时,如果元素需要使用 transform 定位也是可以的了:

.target {
    position: fixed;
    left: 50%; top: 50%;
    --transform: translate(-50%, -50%);
}

此时,动画执行的时候,会把 --transform 的属性值自动插入进去。

如果元素没有设置 --transform 变量,也没有关系,动画会单纯按照 scale(.1) -> scale(1) 进行动画,功能完全不受影响。

关于这个例子,我专门做了在线demo,您可以狠狠地点击这里: transform多CSS属性值依然动画效果demo

几个多值CSS属性示意

CSS多值属性还是很多的,一种是缩写属性(使用空格和斜杠分隔),还有一种是可无限值属性(使用逗号分隔)。

除了 transform 属性外,常见的还有:

filter: invert(1) hue-rotate(.5turn) var(--filter,);
background: linear-gradient(deeppink, deepskyblue) var(--bgcolor,);
box-shadow: 2px 2px 4px #0003 var(--box-shadow,);

以及 grid, border-image, columns, offsets, text-decoration 等非常多的属性,就不一一举例了。

对了,对于逗号分隔的多数组值,在定义CSS变量的时候,前面记得把逗号写上。

--box-shadow: ,0 0 5px #0002;

四、结语说明

一句话,CSS变量赛高之神。

目前在移动端项目中大家可以放心使用,其实我看很多 PC 网站都在使用了,比方说 Bilibili,这玩意真的好事,很多特性都很强,例如各种类型的 CSS 属性值都能支持,容错性也强到离谱,远不是大家认为的换换颜色这么简单。

本文地址: https://www.zhangxinxu.com/wordpress/?p=10440

链接: https://fly63.com/article/detial/11709

css自定义变量_初次接触CSS变量

本文的目的主要是展示CSS变量是如何工作的。随着Web应用程序变得越来越大,CSS变得越来越大,越来越多,而且很多时候都很乱,在良好的上下文中使用CSS变量,为您提供重用和轻松更改重复出现的CSS属性的机制。

CSS变量(自定义属性)实践指南

Sass和Less这样的预处理器,让我们的CSS代码保持良好的结构和可维护性。像变量、混合(mixins)、循环控制等特性,增强了动态编写CSS的能力,从而减少重复代码,也加快了我们开发速度。

css变量_原生css 中变量的使用

原生css 中变量的使用,这个重要的 CSS 新功能,所有主要浏览器已经都支持了。本文全面介绍如何使用它,你会发现原生 CSS 从此变得异常强大。声明变量的时候,变量名前面要加两根连词线(--),var()函数用于读取变量。

理解var let const区别

JavaScript中var、let、const区别?js中let和const都是es5版本新的命名规范,在此之前定定义一个变量只能用var。我们可以把let和const看做是为了弥补var的一些不足而新设计出来的

一个例子,变量提升和函数提升就是这么简单!

引擎在读取js代码的过程中,分为两步。第一个步骤是整个js代码的解析读取,第二个步骤是执行。在JS代码执行之前,浏览器的解析器在遇到 var 变量名 和function 整个函数 提升到当前作用域的最前面。

CSS变量使用解析

很早直接就了解到CSS变量相关的内容,奈何之前使用价值不高(很多主流浏览器不兼容),最近发现主流浏览器都已经支持了这一变化,CSS变量就像JS的变量,每个类名或者花括号就像一个function,里面的变量只有上下文以内可以获取,这就让CSS有了更多可能性。

let与var的区别,为什么要用let?

var是全局声明,let是块级作用的,只适用于当前代码块;var变量会发生变量提升,let则不会进行变量提升;var 会造成重复赋值,循环里的赋值可能会造成变量泄露至全局

ES6-变量的解构赋值

解构赋值官方解释:按照一定的模式,从数组和对象中提取值,对变量进行赋值,这被称为解构(Destructuring)。变量的解构赋值就是一种写法,掌握了这种写法可以让我们在书写 javascript 代码时可以更加的简单,迅捷。

JS中变量的存储

JS中的变量是保存在栈内存中的:1.基本数据类型的值直接在栈内存中存储;2.值与值之间是独立存在的,修改一个变量不会影响其他变量;对象是保存到堆内存中的,每创建一个新的对象

js 交换变量值的方法总汇

这篇文章总结七种办法来交换a和b的变量值 。最最最简单的办法就是使用一个临时变量了 ,最后我的方案是利用了ES6的解构赋值语法 ,它允许我们提取数组和对象的值,对变量进行赋值

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!