全新的CSS相对颜色语法-使用from和calc()

这篇文章发布于 2024年12月11日,星期三,23:56,归类于 CSS相关。 阅读 154 次, 今日 151 次 没有评论

 

月亮猫 相对颜色 占位封面图

无论是rgb()颜色函数,还是hsl()颜色函数,现在还支持一种使用from关键字的相对语法,可以基于现有的色值设置相似色或互补色。

特别适合用在hover等交互效果的实现上。

一、相对语法本质是解构

先来学习下语法,这语法看起来花里胡哨,其实很简单,一学就会。

例如,设置一个文字颜色为红色:

p {
  color: rgb(from red r g b / alpha);
}

实时渲染效果如下:

我是文字,看看我的颜色是啥子?

如果你使用的是Chrome浏览器,或者Safari版本在18以上,就可以看到上面的文字(含外面的虚点)都会是红色。

而其中的 r g b 以及 alpha 实际上是对red的解构,其计算值分别是255 0 0 / 1(或者100%)。

于是,我们就可以基于结构后的值进行对应的颜色设置处理。

1. 直接设置

r g b 以及 alpha可以直接使用数值进行替换,从而改变color的计算值。

例如,50%透明度的red颜色,我们可以这般设置:

p {
  color: rgb(from red r g b / .5);
}

实时渲染效果如下:

我是50%的透明红色吗?

此方法要比使用color-mix()更简单,但是color-mix()支持更早,兼容性更好,详见“CSS好用的color-mix颜色函数也可以使用啦”一文。

又例如,紫色的rgb色值是rgb(255,0,255),因此,我们把上面代码中的b换成255,就可以得到紫色。

p {
  color: rgb(from red r g 255 / alpha);
}

真实的颜色计算结果如下:

紫色是我,我是紫色,啦啦啦😝

注意,实际开发,我们不会使用上面这种用法,这里只是为了展示语法作用。

二、使用calc()用于实战

在生产过程中,我们一般都是使用calc()函数,对结构的色值进行相对计算处理,原因很简单,如果你已经知道具体的色值,那还使用相对语法作甚,岂不多此一举。

1. 语法示意,红色减半

例如:

canvas {
  background-color: rgb(from red calc(r / 2) g b / alpha);
  /* 等同于 rgb(128,0,0) */
}

此时,就是深红色背景,截图渲染结果:

上面这个例子其实也不常用,只是给大家演示下calc()的用法。

2. 文字自动适配背景色

开始进入正题了。

其实文字自动适配背景色很多年前我就介绍过,不过,是需要将r, g, b分别作为变量表示才可以,详见此文“CSS文字和背景color自动配色技术简介”,写于2018年,已经有6年多了。

此时再看依然不过时。

现在有了color色值的相对语法,我们的实现就简单多了。

假设有一个按钮,类名是btn

<button class="btn">我是按钮</button>

则下面这段CSS代码就可以轻松实现,按钮的文字和边框颜色根据背景色自动适配的效果:

.btn {
    font-size: 150%;
    padding: .5em 2em;
    --bgcolor: var(--color, #2c87ff);
    background-color: var(--bgcolor);
    color: hsl(from var(--bgcolor) h s calc((l - 60) * -999999));
    --border-alpha: calc((var(--lightness) - var(--border-threshold))* 100);
    border: .2em solid;
    border-color: hsl(from var(--bgcolor) h s calc(l - 20 * clamp(-1, calc(l - 50), 1)));
}

眼见为实,您可以狠狠地点击这里:使用CSS相对颜色实现按钮文字和背景色自动适配demo

我们改变演示页面的颜色选择输入框的值,就可以看到,随着颜色的不同,按钮的文字自动适配白色或者黑色,而边框色,则在浅色背景下使用深色,深色背景下使用浅色,很智能实现效果,效果如下录屏所示(不动点击播放):

3. 悬停点击等邻近色变化

hover一个文字链接,颜色会适当高亮。

在过去,我们会选择两个不同的色值处理。

现在,除了使用color-mix()(和白色混合),还可以使用这里的相对颜色语法,不过不能使用rgb()函数了,而需要使用hsl()函数,因为这种交互的颜色变化,都是亮度或饱和度这块的调整,hsl()函数再合适不过了。

例如:

<a href class="link">我是链接</a>
.link {
    --color: #2a80eb;
    color: var(--color);
}
.link:hover {
    color: hsl(from var(--color) h s calc(l + 10));
}

类似的,按钮点击的时候,背景色会适当加深。

除了使用box-shadow内阴影模拟,filter属性的brightness亮度滤镜设置,还可以试试相对色值。

使用示意:

<button class="btn">我是按钮</button>
.btn {
    --color: #2a80eb;
    background-color: var(--color);
    color: #fff;
    border: 0;
}
.btn:active {
    background-color:hsl(from var(--color) h s calc(l - 10));
}

以上案例均可体验,您可以狠狠地点击这里:CSS相对颜色鼠标悬停或点击交互变色demo

相对颜色在常见交互中的应用

三、新特性多到让人麻木

CSS相对颜色目前所有现代浏览器都已经支持了,参见下面的截图:

相对颜色语法兼容性示意

也就最近一段时间支持的。

按照过往的经验,2年后可以在类似中台这样的项目环境中使用。

其实纵观我2024年的文章,绝大多数都是新特性介绍,每周一个,都介绍不完,新特性实在太多了。

很多新特性功能有重叠,例如CSS嵌套和CSS @scope语法,CSS相对颜色和CSS color-mix()等。

关键这些特性浏览器支持情况参差不齐,短时间无法在生产环境应用,导致,在社区里基本上鲜有人问津。

现有的JavaScript能力已经足够应付目前所有的交互场景了。

这些锦上添花的东西由于缺少迫切性和必要性,很难被人重视,被重视反而就怪了。

感觉制定规范的那群家伙,也是为了绩效拼命推陈出新,越多越强到底是好事还是错误的方向,只能时间告诉答案了。

好了,就说这么多吧,感谢阅读,欢迎

学不完了 表情包

(本篇完)

分享到:


发表评论(目前没有评论)