51工具盒子

依楼听风雨
笑看云卷云舒,淡观潮起潮落

了解infinity、pi等CSS calc()计算关键字


封面图-蒲公英

一、calc()函数支持的新关键字

CSS在不断发展,除了新支持了若干数学函数之外,还支持了一些数学关键字,且这些关键字和JavaScript中的关键字神似。

包括:

e {#e}

: log常量,约等于:2.7182818284590452354.

pi {#pi}

: 圆周率,约等于:3.1415926535897932.

infinity & -infinity {#infinity}

: 无穷大和无穷小

NaN {#nan}

: 表示非数值。

其中,epi比较容易理解,我们可以借助这些常量和特性数学函数~~实现缓动或正余弦函数动画效果~~(可以是可以,但比较牵强),这个后面会有案例。

需要花些时间了解的是infinity这个关键字。

二、了解infinity关键字及其应用

先看一个案例,已知有如下HTML和CSS代码,请问对话框元素的上下堆叠顺序依次是多少?

<dialog class="a" open>1</dialog>
<dialog class="b" open>2</dialog>
<dialog class="c" open>3</dialog>
<dialog class="d" open>4</dialog>
.a {
  z-index: 99999999;
}
.b {
  z-index: calc(1 / 0);
}
.c {
  z-index: calc(infinity + 1);
}
.d {
  z-index: calc(infinity * 1);
}

大家可以思考下。
.
.
.
.
下面公布答案,从下往上的层叠顺序依次是1、2、3、4,就是DOM的前后顺序。

在CSS中,z-index属性有个最大上线的计算值是2147483647,现在有了infinity,这个值就不是最大值了。

综合上述案例,我们可以得到以下一些结论:

  1. infinity的层级大于任何具体数值的层级。
  2. calc(1 / 0)的计算值就是无穷大infinity
  3. infinity和其他数值加减乘除,还是infinity
  4. infinity只能在calc()函数中使用,不可单独作为关键字。

理论应用

理论上,infinity可以用在任何需要大值的场景下。

例如屏幕外隐藏,之前我们的CSS代码可能是:

.element {
    left: -9999px;
}

如今也可以使用如下所示的代码代替:

.element {
    left: calc(-infinity * 1px);
}

类似的还有圆角,可以让任意尺寸的按钮的圆角都是饱满的:

.element {
    border-radius: calc(infinity * 1px);
}

圆角大小饱满

然而理论归理论,实际上却不建议使用infinity去实现类似的效果。

一是拼写麻烦代码量大,而是根本就没有必要。

例如,元素屏幕外隐藏,直接3个窗口宽度大小足矣,没必要搞个什么无限小:

.element {
    left: -300vw;
}

圆角也是类似,我就不信页面上有什么按钮的圆角大小有屏幕这么大,因此,下面这个单位值足矣:

.element {
    border-radius: 99vw;
}

像我平时用的更多的是9rem,足矣:

.element {
    border-radius: 9rem;
}

只有某些特殊的边界计算场景,我觉得才需要infinity关键字出马。

实际应用

场景如下,项目完成进度条,如果超过80%,则变绿,否则是红色。

其中,80%这个边界变化的关键点,就可以使用infinity实现。

<div class="bar" style="--percent: 40;"></div> 
<div class="bar" style="--percent: 81;"></div>

.bar {
    width: 240px;
    height: 18px;
    border: 1px solid;
    color: hwb(min(calc((var(--percent) - 80) * infinity), 150) 0% 25%);
}
...

当--percent大于80的时候,hwb()色值的H就是150,如果小于80,则是极小的负值,也就是0,此时颜色是红色,就可以实现我们的需求了。

进度条效果示意

眼见为实,您可以狠狠地点击这里:CSS infinity边界状态改变进度条样式demo

三、pi和e的实际应用

思来想去,不就是两个常数嘛,有个啥子高大上的应用哦。

没,e常量可以用来实现衰减,但CSS自带的缓动函数ease等更好用,pi表示圆周率,嗯......只有一个特殊的环形排版可能会出面一下下吧。

不过为了方便大家学习,我还是强扭了个demo,用e和pi常量弄的仅供学习的示意案例。

HTML如下:

<img id="e" class="e" src="1.jpg" />
<p><button onClick="e.classList.add('active');">点击图片运动</button></p>
<img id="pi" class="pi" src="1.jpg" />
<p><button onClick="pi.classList.add('active');">点击图片运动</button></p>

{#code}


CSS则是:

@property --seed {
  syntax: "<integer>";
  inherits: false;
  initial-value: 0;
}
@keyframes seed {
    from { --seed: 0; }    
    to { --seed: 100; }    
}
img.active {
    animation: seed 1s linear both;
}
.e {
    translate: calc(1px * pow(var(--seed) / 16, e)) 0;
}
.pi {
    rotate: calc(4 * atan(calc(pi * var(--seed) / 100)));
}

{#code}

各种语法和花里花哨的CSS数学函数计算大家略,只要知道,点击按钮,就有动画效果就好了。

动画中截图示意

若想直观体验,您可以狠狠地点击这里:CSS e和pi常量与动画效果demo

四、结语碎碎念

仿佛回到了以前,一个小小的点也撤出那么多东西。

好吧,开始进入大家都喜欢看的本周碎碎念环节。

小朋友终于开始学游泳了,两个一起学,找了个小区内部的游泳池,比商业区的泳池要便宜不少,性价比还不错。

学游泳

小区里面的车越来越多了,嘎吱角落都塞满了车。

车子里面的钓箱终于清出来了,现在都是用钓椅了,家里领导不让带到家里占地方,就放在了另外一辆买菜车里面。

周末两天都是38、39度的高温,还是钓了两天的鱼,我不怕热,怕冷,夏天办公都要外套披身,一是因为体脂率低,散热快,二是从小户外暴晒习惯了。

周六大混养,钓了近40斤,周日钓鲤鱼51斤鱼,发挥一般,失误较多,需要好好总结下。

渔获

本周CSS世界三部曲精讲视频到了第9集 功勋卓越的border属性

对了,新书《HTML并不简单》(原名《你并不精通HTML》)本周刚刚上架,大家可以关注下,然后签名版目前5折,京东博文视点独家出售

书封

(本篇完)

赞(2)
未经允许不得转载:工具盒子 » 了解infinity、pi等CSS calc()计算关键字