效果预览

在线演示

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

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

可交互视频教程

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

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

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

源代码下载

本地下载

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

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

代码解读

定义 dom,容器表示整只蝴蝶,因为蝴蝶是对称的,所以分为左右两边,每边有 3 个子元素:

<div class="butterfly">
<div class="left">
<span></span>
<span></span>
<span></span>
</div>
<div class="right">
<span></span>
<span></span>
<span></span>
</div>
</div>

居中显示:

body {
margin: 0;
height: 100vh;
display: flex;
align-items: center;
justify-content: center;
background: linear-gradient(gray, lightyellow, gray);
}

定义蝴蝶的尺寸:

.butterfly {
position: relative;
width: 10em;
height: 10em;
}

先画左半边:

.butterfly .left {
position: absolute;
width: inherit;
height: inherit;
}

用第 1 个子元素画出翅膀的上半部分:

.butterfly span {
position: absolute;
border-radius: 50%;
} .butterfly span:nth-child(1) {
width: 5em;
height: 7em;
background-color: gold;
}

用第 2 个子元素画出翅膀的下半部分:

.butterfly span:nth-child(2) {
width: 5.5em;
height: 3.5em;
background-color: orangered;
top: 5em;
left: -2.5em;
filter: opacity(0.6);
}

用第 3 个子元素画出触角:

.butterfly span:nth-child(3) {
width: 6em;
height: 6em;
border-right: 0.3em solid orangered;
top: -0.5em;
}

把左半边复制一份到右半边:

.butterfly .right {
position: absolute;
width: inherit;
height: inherit;
} .butterfly .right {
transform: rotateY(180deg) rotate(-90deg);
top: 0.4em;
left: 0.4em;
}

把标本装到展示框里:

.butterfly::before {
content: '';
position: absolute;
box-sizing: border-box;
top: -2.5em;
left: -8em;
width: 24em;
height: 18em;
background-color: black;
border: 0.2em inset silver;
} .butterfly::after {
content: '';
position: absolute;
box-sizing: border-box;
width: 40em;
height: 30em;
background-color: lightyellow;
top: -9em;
left: -16em;
border: 2em solid burlywood;
border-radius: 3em;
box-shadow:
0 0.3em 2em 0.4em rgba(0, 0, 0, 0.3),
inset 0.4em 0.4em 0.1em 0.5em rgba(0, 0, 0, .4);
z-index: -1;
}

最后,调整一下因图案倾斜引起的位移:

.butterfly {
transform: translateX(1em);
}

大功告成!

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

最新文章

  1. grep 命令过滤配置文件中的注释和空行
  2. ABP理论学习之N层架构
  3. 如何使用Python在Kaggle竞赛中成为Top15
  4. css012 css布局简介
  5. JavaScript操作数组
  6. Eclipse中对Python代码自动格式化!
  7. linux高可用集群(HA)原理详解(转载)
  8. Windows Phone 学习笔记(一) 数据存储
  9. 动态代理双剑客--JDK Proxy与CGLIB
  10. 大大维的贪吃蛇v1
  11. 正常启动HBase顺序
  12. Spring3.1 对Bean Validation规范的新支持(方法级别验证)
  13. 笔记: c开发gui程序 (WM_CREATE, WS_CLIPCHILDREN , SetWindowPos)
  14. Java并发编程(1)-Java内存模型
  15. go语言学习-常用命令
  16. 关于军训的模拟赛-R2
  17. 关于面试总结13-app测试面试题
  18. 基于VM10+Win7安装Mac OSX10.11 El Capitan
  19. Could not find RubyGem cocoapods 错误
  20. linux系统管理(1)之 内核编译选项查看

热门文章

  1. 在Mac上安装Ubuntu14.04虚拟机
  2. nginx 设置websocket支持
  3. JToken和JObject有什么区别
  4. UVa12304(计算几何中圆的基本操作)
  5. 解决 openSUSE 中 Sublime Text 3 的中文显示和输入问题
  6. python学习之串口编程
  7. 17999 Light-bot 模拟 + kmp求循环节
  8. 181. 将整数A转换为B
  9. java中 awt Graphics2D
  10. (转)Quirks模式与standards模式区别