效果预览

在线演示

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

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

最新文章

  1. ES5基础之正则表达式01:初次见面
  2. C#编程语言与面向对象——继承
  3. RabbitMQ 发布/订阅
  4. 更新Xcode7 后 .dylib变成了.tbd的问题解决
  5. JavaWeb学习笔记之Servlet(一)
  6. C语言中指针变量如何向函数中传递
  7. 【一天一道LeetCode】#27. Remove Element
  8. 阿里云ECS Centos7 系统安装图形化桌面
  9. Scala常用变量生命周期
  10. 团队项目7——团队冲刺beta版本目录
  11. java学习(二)基础概念、语法
  12. Asp.Net 之 <%%>相关内联代码块用法
  13. Hibernate 缓存机制详细解析
  14. java练习题——类与对象
  15. JS使用replace替换字符串中的某段或某个字符
  16. split一些分开一些特殊字符
  17. cisco packet 实验教程(一)
  18. ASP.NET MVC 学习笔记-7.自定义配置信息 ASP.NET MVC 学习笔记-6.异步控制器 ASP.NET MVC 学习笔记-5.Controller与View的数据传递 ASP.NET MVC 学习笔记-4.ASP.NET MVC中Ajax的应用 ASP.NET MVC 学习笔记-3.面向对象设计原则
  19. myeclipse工具常用的用法
  20. 关于OpenCV图像操作的默认参数问题

热门文章

  1. bzoj 3513: [MUTC2013]idiots【生成函数+FFT】
  2. 1856: [Scoi2010]字符串(Catalan数)
  3. hive的使用 + hive的常用语法
  4. UvaLive6441(期望概率dp)
  5. Educational Codeforces Round 24 A
  6. Dima and Magic Guitar CodeForces - 366E
  7. 优先队列 POJ 2431 Expedition
  8. Contextual Action bar(2) 简介,启动,各函数介绍
  9. 什么是极坐标? —— 一点微小的想法 What is Polar Coordinate ? - Some Naive Thoughts about It
  10. Sqlserver调用WebApi