社区精选 | 让CSS计数器支持小数的动态变化?
今天小编为大家带来的是社区作者 XboxYan 的文章,让我们一起来学习用 CSS计数器实现小数的动态变化。
不得不说,CSS 计数器是个好东西。
最近在几篇文章中都用到了 CSS 计数器,可以将 CSS 变量通过伪元素content动态展示出来,还可以做出很多有趣的动画。有兴趣的可以先回顾一下之前的这几篇文章:
还在使用定时器吗?CSS 也能实现电子时钟 https://segmentfault.com/a/1190000041661094 动画合成小技巧!CSS 实现动感的倒计时效果 https://segmentfault.com/a/1190000042094549 自定义计数器小技巧!CSS 实现长按点赞累积动画 https://segmentfault.com/a/1190000042360785
count::before {
--percent: 50;
counter-reset: progress var(--percent);
content: counter(progress);
}
data:image/s3,"s3://crabby-images/80df7/80df75a43a305200fc13d73ee061a9a5634f52e8" alt="image-20220827130618618"
count::before {
--percent: 50.15;
counter-reset: progress var(--percent);
content: counter(progress);
}
data:image/s3,"s3://crabby-images/49aaf/49aafd9c15922a6b112c5711aa5fa33f2c736d49" alt="image-20220827130753591"
data:image/s3,"s3://crabby-images/b3b7c/b3b7c2786994b3e167b1b48196b8388f7d069993" alt=""
一、CSS 原理拆解
data:image/s3,"s3://crabby-images/71317/7131773ad60ebd0969e27e73543c0b40327568b2" alt="image-20220827131936587"
count::before {
--整数: 48;
--小数: 69;
counter-reset: 整数计数器 var(--整数) 小数计数器 var(--小数);
content: counter(整数计数器) "." counter(小数计数器);
}
data:image/s3,"s3://crabby-images/f8cd4/f8cd41c1125aed2d13c8dfff8c5ba3219803cc90" alt="image-20220827131530150"
二、CSS变量拆分成整数和小数
count::before {
--percent: 48.69;
--整数: 48;
--小数: 69;
counter-reset: 整数计数器 var(--整数) 小数计数器 var(--小数);
content: counter(整数计数器) "." counter(小数计数器);
}
<length> <number> <percentage> <length-percentage> <color> <image> <url> <integer> <angle> <time> <resolution> <transform-function> <custom-ident> <transform-list>
<number>表示任意的数字,整数和小数都可以 <integer>表示整型数字,只能是整数,小数会认为不合法
@property --整数 {
syntax: "<integer>"; /*整型*/
initial-value: 0;
inherits: false;
}
@property --整数 {
syntax: "<integer>"; /*整型*/
initial-value: 0;
inherits: false;
}
data:image/s3,"s3://crabby-images/30d7a/30d7a8c38696b9a85be33fb508c5e4be534f2094" alt="image-20220827134012420"
count::before {
--percent: 48.69;
--整数: calc(48.69);/*使用 CSS 计算后可以转换成整数*/
--小数: 69;
counter-reset: 整数 var(--整数) 小数 var(--小数);
content: counter(整数) "." counter(小数);
}
@property --整数 {
syntax: "<integer>";
initial-value: 0;
inherits: false;
}
count::before {
--percent: 48.69;
--整数: calc(var(--percent) - 0.5);
--小数: 69;
counter-reset: 整数 var(--整数) 小数 var(--小数);
content: counter(整数) "." counter(小数);
}
data:image/s3,"s3://crabby-images/40048/40048452d525f2315bc87004a001faf12e539d4a" alt="image-20220827144136572"
@property --小数 {
syntax: "<integer>";
initial-value: 0;
inherits: false;
}
count::before {
--percent: 48.69;
--整数: calc(var(--percent) - 0.5);
--小数: calc((var(--percent) - var(--整数)) * 100 - 0.5);
counter-reset: 整数 var(--整数) 小数 var(--小数);
content: counter(整数) "." counter(小数);
}
data:image/s3,"s3://crabby-images/0de32/0de32fabe3972b5108cebc98e9555d8fca6b99b5" alt="image-20220827135400459"
data:image/s3,"s3://crabby-images/2097f/2097ff5143440d3eed66a5ad9fba2527eb5249e8" alt="image-20220827140549249"
count::before {
--percent: 48.69;
--整数: calc(var(--percent) - 0.5);
--小数: calc((var(--percent) - var(--整数)) * 100 - 0.5 + 0.01);
counter-reset: 整数 var(--整数) 小数 var(--小数);
content: counter(整数) "." counter(小数, decimal-leading-zero);
}
三、CSS 变量动画
count::before {
--percent: 0.4869;
--百分比: calc(var(--percent) * 100);
--整数: calc(var(--百分比) - 0.5);
--小数: calc((var(--百分比) - var(--整数)) * 100 - 0.5 + 0.01);
counter-reset: 整数 var(--整数) 小数 var(--小数);
content: counter(整数) "." counter(小数, decimal-leading-zero) "%";
}
data:image/s3,"s3://crabby-images/ec600/ec600cdd48bfeccedeb83c6e3f4c0b8b92cc7c4b" alt="image-20220827141156639"
count.addEventListener('click', ev => {
ev.target.style.setProperty("--percent", Math.random());
})
data:image/s3,"s3://crabby-images/7ae44/7ae440fc0ba8cf2df39f0546cfee0d61d87e8807" alt=""
@property --percent {
syntax: "<number>";
initial-value: 0;
inherits: false;
}
count{
/**/
transition: --percent 1s
}
data:image/s3,"s3://crabby-images/abd7d/abd7dbde95a83334d0d374e63aed28ebbdbaecbc" alt="640 (1).gif"
count{
/**/
transition: --整数 1s, --小数 1s;
}
data:image/s3,"s3://crabby-images/b3b7c/b3b7c2786994b3e167b1b48196b8388f7d069993" alt=""
@property --percent {
syntax: "<number>";
initial-value: 0;
inherits: false;
}
@property --整数 {
syntax: "<integer>";
initial-value: 0;
inherits: false;
}
@property --小数 {
syntax: "<integer>";
initial-value: 0;
inherits: false;
}
count {
--percent: 0.4512;
font-size: 60px;
font-weight: bolder;
cursor: pointer;
font-family: 'Courier New', Courier, monospace;
--百分比: calc(var(--percent) * 100);
--整数: calc(var(--百分比) - 0.5);
--小数: calc((var(--百分比) - var(--整数)) * 100 - 0.5 + 0.01);
counter-reset: 整数 var(--整数) 小数 var(--小数);
transition: --整数 1s, --小数 1s;
}
count::before {
content: counter(整数) "." counter(小数, decimal-leading-zero) "%";
}
四、总结和说明
CSS 变量不支持直接在content中渲染,但是可以借助计数器初始化来实现 CSS 计数器不支持小数初始化 CSS 计数器支持小数的实现原理在于将小数拆分为整数、小数点、小数三个部分 CSS 自定义变量可以指定变量的类型,这样通过 CSS 数学函数可以将一个小数转换成整数 小数部分可以通过减去整数部分得到 小数部分还需要通过decimal-leading-zero补全位数 CSS 单一变量一方面可以带来更好的可维护性,另一方面还可以更轻易地实现过渡动画 借助 @property可以很方便的控制 CSS 变量的过渡和动画
data:image/s3,"s3://crabby-images/76496/764964b81d65c627ddc355ff12709a17f66cccc4" alt=""
data:image/s3,"s3://crabby-images/b60b1/b60b14d17e5c92a8595a864ba05d4603dd2b9729" alt=""
关注公众号:拾黑(shiheibook)了解更多
赞助链接:
关注数据与安全,洞悉企业级服务市场:https://www.ijiandao.com/
四季很好,只要有你,文娱排行榜:https://www.yaopaiming.com/
让资讯触达的更精准有趣:https://www.0xu.cn/
data:image/s3,"s3://crabby-images/dafa2/dafa23923137f9ee358445f4e4cde32f18d0d7c0" alt="公众号"
随时掌握互联网精彩
- httpstat更美观的HTTP性能监测工具
- flutter_server_box一款手机端SSH工具
- 韩元汇率对人民币2023年8月19日
- 美国国防部发起5G Open RAN挑战赛 奖金高达700万美元
- 切片分组网SPN算力网络新突破——中国移动研究院、中国移动浙江公司联合烽火通信率先完成算网SPN现网试点
- 国家战略性力量——商业航天定位的再思考
- 上亿人围观!小眼睛博主竟被智能车误判开车睡觉,何小鹏亲自回
- GSMA Julian Gorman与华为徐速:亚太5G发展领跑全球 广泛生态合作是关键
- 《2021战略调查》全球战略趋势:2022年国家安全五大挑战!
- 保护低龄读者,晋江文学城开启分级制
- 数字化转型之路,怎么走?
- 人脸信息滥用触目惊心,商用逐利边界何在?
赞助链接