效果预览

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

https://codepen.io/comehope/pen/GBzLdy

可交互视频

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

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

https://scrimba.com/p/pEgDAM/cGENVuR

源代码下载

每日前端实战系列的全部源代码请从 github 下载:

https://github.com/comehope/front-end-daily-challenges

代码解读

定义 dom,容器中包含 10 个元素,每个元素代表 1 个圆环:

<div class="circles">
<span></span>
<span></span>
<span></span>
<span></span>
<span></span>
<span></span>
<span></span>
<span></span>
<span></span>
<span></span>
</div>

居中显示:

body {
margin: 0;
height: 100vh;
display: flex;
align-items: center;
justify-content: center;
background-color: lightgoldenrodyellow;
}

定义容器尺寸和其中子元素的布局方式:

.circles {
width: 10em;
height: 10em;
font-size: 30px;
border: 1px dashed black;
display: flex;
justify-content: center;
}

为每个圆环定义下标变量:

.circles span:nth-child(1) {
--n: 1;
} .circles span:nth-child(2) {
--n: 2;
} .circles span:nth-child(3) {
--n: 3;
} .circles span:nth-child(4) {
--n: 4;
} .circles span:nth-child(5) {
--n: 5;
} .circles span:nth-child(6) {
--n: 6;
} .circles span:nth-child(7) {
--n: 7;
} .circles span:nth-child(8) {
--n: 8;
} .circles span:nth-child(9) {
--n: 9;
} .circles span:nth-child(10) {
--n: 10;
}

设置每个的圆环的尺寸,颜色黑白间隔:

.circles {
position: relative;
} .circles span {
position: absolute;
--diameter: calc(10em - (var(--n) - 1) * 1em);
width: var(--diameter);
height: var(--diameter);
border-radius: 50%;
} .circles span:nth-child(odd) {
background-color: darkred;
} .circles span:nth-child(even) {
background-color: gold;
}

把尺寸最小的 3 个圆环向下移动,形成凹陷的效果:

.circles span:nth-child(n+8) {
top: calc((var(--n) - 7) * 1em);
}

让容器旋转起来,就好像一只监视的眼睛转来转去:

.circles {
animation: rotating 5s linear infinite;
} @keyframes rotating {
to {
transform: rotate(1turn);
}
}

大功告成!

最新文章

  1. Android事件总线
  2. [原创] C# dynamic拼接Json串
  3. 那些年用过的xUnit.net的简单用法
  4. 多平台下Modbus通信协议库的设计(一)
  5. .net弹出框
  6. 用 Fabric 实现自动化部署
  7. Selenium Webdriver元素定位的常用方式
  8. mysql插入表中的中文显示为乱码或问号的解决方法
  9. mybatis generator 使用
  10. 【转】常用Maven插件
  11. JAVA自学笔记23
  12. ansible一键部署k8s单机环境
  13. Announcing WebKit SDL port
  14. js 中class选择器,addClass,removeClass,hasClass,toggleClass,getByClass
  15. 升级到yosemite后homebrew报错的解决
  16. 玩转X-CTR100 l STM32F4 l U-Blox NEO-6M GPS卫星定位-nmealib解码库移植解码
  17. java.lang.IllegalStateException: Cannot call sendError() after the response has been committed解读
  18. [TensorFlow] tf.nn.softmax_cross_entropy_with_logits的用法
  19. 硬币问题 tarjan缩点+DP 莫涛
  20. qt资源下载网站

热门文章

  1. HTML-字符实体,平方米(㎡)m&#178;
  2. java c 标签的使用
  3. 编程语言-Java-问题整理
  4. Python入门习题10.河内塔(汉诺塔)问题
  5. 3、NumPy 数组属性
  6. each of which 用法
  7. Codeforces - 1088B - Ehab and subtraction - 堆
  8. cocos2d-x 3.0正式版创建project笔记
  9. git-vi
  10. web前端之html基础知识初级