如何用纯 CSS 创作一个蝴蝶标本展示框
CSS 如何 一个 展示 创作 用纯
2023-09-27 14:26:43 时间
![](http://www.jqhtml.com/wp-content/uploads/2018/11/1396116987-5b1b9a1b45db9_articlex.png)
效果预览
在线演示按下右侧的“点击预览”按钮可以在当前页面预览,点击链接可以全屏预览。
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相关文章
- css hack 如何区分 ie7 ie8
- 弄懂css动画知识点
- CSS中动画——如何设置关键帧,8个动画属性及简写方式
- CSS中表格介绍,表格相关的样式以及长表格的使用
- css 设置背景图片透明
- 1. web前端开发分享-css,js入门篇
- HTML之表单类控件、图像类元素的CSS特别样式汇总
- 如何用纯 CSS 创作一组昂首阔步的圆点
- 如何用纯 CSS 和 D3 创作一只扭动的蠕虫
- 如何用纯 CSS 创作一个行驶中的火车 loader
- 如何用 CSS 和 D3 创作一个无尽的六边形空间
- 如何用纯 CSS 创作一个方块旋转动画
- 如何用纯 CSS 创作一副国际象棋
- 如何用纯 CSS 创作一个雷达扫描动画
- 如何用纯 CSS 绘制一个充满动感的 Vue logo
- 如何创作用纯 CSS 绘制一支栩栩如生的铅笔
- 如何用纯 CSS 创作一种按钮被瞄准的交互特效
- 如何用纯 CSS 创作一个 3D 文字跑马灯特效
- 如何用 CSS 创作一个立体滑动 toggle 交互控件
- 使用chrome console检查css selector/xpath的有效性|百度云盘如何获取文件库中的目录文字
- css sprites 图片位置计算
- 【CSS/JS学习】如何实现单行/多行文本溢出的省略(...)--老司机绕过坑道的正确姿势
- 浏览器原理 22 # 渲染流水线:CSS如何影响首次加载时的白屏时间?
- 【前端基础面试题】如何用CSS画一个三角形(详解)