分享web开发知识

注册/登录|最近发布|今日推荐

主页 IT知识网页技术软件开发前端开发代码编程运营维护技术分享教程案例
当前位置:首页 > 前端开发

如何用纯 CSS 创作一个充电 loader 特效

发布时间:2023-09-06 02:23责任编辑:熊小新关键词:CSS

效果预览

在线演示

按下右侧的“点击预览”按钮在当前页面预览,点击链接全屏预览。


https://codepen.io/zhang-ou/pen/deNqdV


可交互视频教程


此视频是可以交互的,你可以随时暂停视频,编辑视频中的代码。


请用 chrome, safari, edge 打开观看。


https://scrimba.com/c/cvrwJAK


源代码下载


本地下载

请从 github 下载。


https://github.com/comehope/front-end-daily-challenges/tree/master/008-charging-loader-animation


代码解读


定义 dom,只有一个容器元素:

<div class="battery"></div>

居中显示:

html, body { ???height: 100%; ???display: flex; ???align-items: center; ???justify-content: center; ???background: linear-gradient(to bottom, teal, aqua);}

画出电池的主体轮廓:

.battery { ???width: 6em; ???height: 3em; ???color: midnightblue; ???border: 0.5em solid currentColor; ???border-radius: 0.2em; ???font-size: 2em;}

画出电池的突起:

.battery { ???position: relative;}.battery::after { ???content: ''; ???position: absolute; ???width: 0.5em; ???height: 2em; ???background-color: currentColor; ???top: 0.5em; ???right: -1em; ???border-radius: 0 0.2em 0.2em 0;}

画出充电电量:

.battery { ???background-image: linear-gradient(to right, whitesmoke, whitesmoke); ???background-repeat: no-repeat; ???background-size: 30% 80%; ???background-position: 0.3em 50%;}

定义和应用动画效果:

@keyframes charge { ???from { ???????background-size: 10% 80%; ???} ???to { ???????background-size: 95% 80%; ???}}.battery { ???animation: charge 5s linear infinite;}

最后,把动画的时间函数由线性变化改为步长变化:

.battery { ???animation: charge 5s steps(8) infinite;}

大功告成!

知识点

linear-gradient() https://developer.mozilla.org/en-US/docs/Web/CSS/linear-gradient

background-size https://developer.mozilla.org/en-US/docs/Web/CSS/background-size

background-position https://developer.mozilla.org/en-US/docs/Web/CSS/background-position

steps() https://developer.mozilla.org/en-US/docs/Web/CSS/single-transition-timing-function#Timing_functions

currentColor https://developer.mozilla.org/en-US/docs/Web/CSS/color_value#Values

border-radius https://developer.mozilla.org/en-US/docs/Web/CSS/border-radius

原文地址:https://segmentfault.com/a/1190000014669547

如何用纯 CSS 创作一个充电 loader 特效

原文地址:https://www.cnblogs.com/lalalagq/p/9986459.html

知识推荐

我的编程学习网——分享web前端后端开发技术知识。 垃圾信息处理邮箱 tousu563@163.com 网站地图
icp备案号 闽ICP备2023006418号-8 不良信息举报平台 互联网安全管理备案 Copyright 2023 www.wodecom.cn All Rights Reserved