效果预览

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

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

可交互视频

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

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

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

源代码下载

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

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

代码解读

定义 dom,容器中包含 3 个子元素:

  1. <div class="parrot">
  2. <div class="outer"></div>
  3. <div class="middle"></div>
  4. <div class="inner"></div>
  5. </div>

居中显示:

  1. body {
  2. margin: 0;
  3. height: 100vh;
  4. display: flex;
  5. align-items: center;
  6. justify-content: center;
  7. background-color: darkslategray;
  8. }

定义容器尺寸:

  1. .parrot {
  2. width: 10em;
  3. height: 10em;
  4. font-size: 30px;
  5. }

画出鹦鹉头部的羽毛:

  1. .parrot {
  2. position: relative;
  3. display: flex;
  4. align-items: center;
  5. justify-content: center;
  6. }
  7. .parrot .outer {
  8. position: absolute;
  9. width: 100%;
  10. height: 100%;
  11. border: 1em solid;
  12. border-color: transparent transparent orangered tomato;
  13. border-radius: 50%;
  14. }

画出鹦鹉的头部和喙的上半部分:

  1. .parrot .middle {
  2. position: absolute;
  3. width: 80%;
  4. height: 80%;
  5. border: 4em solid;
  6. border-color: gold transparent gainsboro white;
  7. border-radius: 50%;
  8. }

画出鹦鹉的喙的下半部分:

  1. .parrot .inner {
  2. position: absolute;
  3. width: 40%;
  4. height: 40%;
  5. border: 2em solid;
  6. border-color: transparent orange transparent transparent;
  7. border-radius: 50%;
  8. }

用伪元素画出鹦鹉的眼睛:

  1. .parrot .inner::before {
  2. content: '';
  3. position: absolute;
  4. width: 1em;
  5. height: 1em;
  6. background-color: black;
  7. border-radius: 50%;
  8. left: -2em;
  9. top: -0.5em;
  10. }

把画面转正:

  1. .parrot > * {
  2. transform: rotate(45deg);
  3. }

设置鼠标悬停效果,悬停时鹦鹉的头转向另一侧:

  1. .parrot > * {
  2. transition: 0.5s;
  3. }
  4. .parrot:hover .outer {
  5. transform: rotate(225deg);
  6. border-color: transparent transparent tomato orangered;
  7. }
  8. .parrot:hover .middle {
  9. transform: rotate(calc(225deg - 360deg));
  10. border-color: transparent gold white gainsboro;
  11. }
  12. .parrot:hover .inner {
  13. transform: rotate(135deg);
  14. }

最后,修改悬停时鹦鹉的配色:

  1. .parrot:hover .outer {
  2. border-color: transparent transparent lightseagreen darkcyan;
  3. }
  4. .parrot:hover .middle {
  5. border-color: transparent gold white gainsboro;
  6. }
  7. .parrot:hover .inner {
  8. border-color: transparent orange transparent transparent;
  9. }

大功告成!

前端每日实战:58# 视频演示如何用纯 CSS 创作一只卡通鹦鹉的更多相关文章

  1. 前端每日实战:73# 视频演示如何用纯 CSS 创作一只卡通狐狸

    效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/OEKZed 可交互视频 此视频是可 ...

  2. 前端每日实战:98# 视频演示如何用纯 CSS 创作一只愤怒小鸟中的绿猪

    效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/VBGWqX 可交互视频 此视频是可 ...

  3. 前端每日实战:124# 视频演示如何用纯 CSS 创作一只纸鹤

    效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/xagoYb 可交互视频 此视频是可 ...

  4. 前端每日实战:103# 视频演示如何用纯 CSS 创作一只监视眼

    效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/GBzLdy 可交互视频 此视频是可 ...

  5. 前端每日实战:132# 视频演示如何用纯 CSS 创作一只思考的手

    效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/WgdVyx/ 可交互视频 此视频是 ...

  6. 前端每日实战:111# 视频演示如何用纯 CSS 创作一只艺术的鸭子

    效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/aaoveW 可交互视频 此视频是可 ...

  7. 前端每日实战:70# 视频演示如何用纯 CSS 创作一只徘徊的果冻怪兽

    效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/VdOKQG 可交互视频 此视频是可 ...

  8. 前端每日实战:61# 视频演示如何用纯 CSS 创作一只咖啡壶

    效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/ZRjGGy 可交互视频 此视频是可 ...

  9. 前端每日实战:62# 视频演示如何用纯 CSS 创作一只蒸锅

    效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/YvOzNy 可交互视频 此视频是可 ...

随机推荐

  1. 【c#技术】一篇文章搞掂:Newtonsoft.Json Json.Net

    一.介绍 Json.Net是一个.Net高性能框架. 特点和好处: 1.为.Net对象和JSON之间的转换提供灵活的Json序列化器: 2.为阅读和书写JSON提供LINQ to JSON: 3.高性 ...

  2. Houdini学习笔记——【案例二】消散文字制作

    [案例二]Houdini消散文字制作 一.Overview     文字通过时间轴中frame变化而碎裂从两边开始向着中间消散并向镜头移动. 效果 二.Sop(Surface OPerators or ...

  3. Shell逻辑运算符及表达式

    一. 运算符总结说明 1. 条件运算符 运算符号 代表意义 应用 说明 = 等于 整型或字符串比较: str1 = str2 字符串str1 和字符串str2 相等时返回真,如果在[]中,只能是字符串 ...

  4. python3+django2 个人简单博客实现 -正在施工

  5. CET-6 分频周计划生词筛选(Week 1)

    Week 1 2016.09.03 p17 bias = prejudice / prejudge p18 diminish p19 distinguish/extinguish + majority ...

  6. 干货 | Bokeh交互式数据可视化快速入门

    Bokeh简介 Bokeh是一款交互式可视化库,在浏览器上进行展示. Bokeh可以通过Python(或其它语言),快速便捷地为大型流数据集提供优雅简洁的高性能交互式图表. 安装 在python中有多 ...

  7. Purfer序列

    我们经常干的一件事是把数变为关于图的问题来解决,那么久了未免不会有这个疑问:能不能把图变成数来解决问题? 所以有了这个purfer数列. 介绍一下这个数列有什么用(或者说有什么性质): 能够将一棵无根 ...

  8. Pycharm 激活码2017最新

    BIG3CLIK6F-eyJsaWNlbnNlSWQiOiJCSUczQ0xJSzZGIiwibGljZW5zZWVOYW1lIjoibGFuIHl1IiwiYXNzaWduZWVOYW1lIjoiI ...

  9. vue侦听属性和计算属性

    监听movies,实现点击添加显示到li标签里面.页面效果如下: <template> <div> <div class="moive"> &l ...

  10. tcpdump 与 抓包分析

    在Windows下一般使用WireShark 抓包软件,tcpdump 是 Linux 系统的抓包软件.它可以抓取 TCP/IP 协议族的数据包,支持针对网络层.协议.主机.端口的过滤,并提供 and ...