效果预览

在线演示

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

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

可交互视频教程

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

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

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

源代码下载

本地下载

请从 github 下载。

https://github.com/comehope/front-end-daily-challenges/tree/master/018-stroke-morphing-404-effects

代码解读

定义 dom,容器中包含 3 个 <p>,每个 <p> 代表 1 个数字;每个 p 标签包含若干 <span>,每个 <span> 代表 1 个笔划:

&lt;section class="four-zero-four"&gt;
&lt;p class="four"&gt;
&lt;span&gt;&lt;/span&gt;
&lt;span&gt;&lt;/span&gt;
&lt;span&gt;&lt;/span&gt;
&lt;/p&gt;
&lt;p class="zero"&gt;
&lt;span&gt;&lt;/span&gt;
&lt;span&gt;&lt;/span&gt;
&lt;span&gt;&lt;/span&gt;
&lt;span&gt;&lt;/span&gt;
&lt;/p&gt;
&lt;p class="four"&gt;
&lt;span&gt;&lt;/span&gt;
&lt;span&gt;&lt;/span&gt;
&lt;span&gt;&lt;/span&gt;
&lt;/p&gt;
&lt;/section&gt;

居中显示:

html, body {
height: 100%;
display: flex;
align-items: center;
justify-content: center;
background: linear-gradient(gray, silver);
}

整体布局:

.four-zero-four p {
width: 10em;
height: 10em;
border: 1px dashed white;
display: inline-block;
margin: 1em;
position: relative;
}

设置笔划共有属性:

.four-zero-four p span {
position: absolute;
box-sizing: border-box;
filter: opacity(0.8);
}

画出数字 4 的笔划:

.four span:nth-child(1) {
width: 20%;
height: 80%;
left: 10%;
} .four span:nth-child(2) {
width: 100%;
height: 20%;
bottom: 30%;
} .four span:nth-child(3) {
width: 20%;
height: 100%;
right: 10%;
}

画出数字 0 的笔划:

.zero span:nth-child(1) {
width: 20%;
height: 100%;
left: 10%;
} .zero span:nth-child(2) {
width: 100%;
height: 20%;
top: 10%;
} .zero span:nth-child(3) {
width: 20%;
height: 100%;
right: 10%;
} .zero span:nth-child(4) {
width: 100%;
height: 20%;
bottom: 10%;
}

给笔划上色:

.four span:nth-child(1) {
background-color: yellowgreen;
} .four span:nth-child(2) {
background-color: turquoise;
} .four span:nth-child(3) {
background-color: pink;
} .zero span:nth-child(1) {
background-color: skyblue;
} .zero span:nth-child(2) {
background-color: plum;
} .zero span:nth-child(3) {
background-color: lightcoral;
} .zero span:nth-child(4) {
background-color: peachpuff;
}

设置划过数字时笔划的变化效果:

.four-zero-four p:hover span {
border: 1px solid black;
background-color: transparent;
filter: opacity(1);
transition: 0.3s;
}

设置划过数字时笔划的偏移量:

.four:hover span:nth-child(1) {
left: 0;
} .four:hover span:nth-child(2) {
bottom: 0;
} .four:hover span:nth-child(3) {
right: 0;
} .zero:hover span:nth-child(1) {
left: 0;
} .zero:hover span:nth-child(2) {
top: 0;
} .zero:hover span:nth-child(3) {
right: 0;
} .zero:hover span:nth-child(4) {
bottom: 0;
}

最后,设置缓动时长:

.four-zero-four p span {
transition: 0.3s;
} .four-zero-four p:hover span {
transition: 0.3s;
}

大功告成!

知识点

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

如何用纯 CSS 创作 404 文字变形为 NON 文字的交互特效的更多相关文章

  1. 前端每日实战:18# 视频演示如何用纯 CSS 创作 404 文字变形为 NON 文字的交互特效

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

  2. 18.纯 CSS 创作 404 文字变形为 NON 文字的交互特效

    原文地址:https://segmentfault.com/a/1190000014818274 感想: positon:absolute  和 :hover HTML代码: <!-- < ...

  3. 如何用纯 CSS 创作一种按钮被瞄准的交互特效

    效果预览 按下右侧的"点击预览"按钮在当前页面预览,点击链接全屏预览. 在线演示 https://codepen.io/zhang-ou/pen/ELWMLr 可交互视频教程 此视 ...

  4. 9.纯 CSS 创作一种按钮被瞄准的交互特效

    原文地址:https://segmentfault.com/a/1190000014680999 吃鸡倍镜,哈哈哈 HTML代码: <div class="box"> ...

  5. 如何用纯 CSS 创作在文本前后穿梭的边框

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

  6. 如何用纯 CSS 创作文本滑动特效的 UI 界面

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

  7. 如何用纯 CSS 创作一种有削铁如泥感觉的菜单导航特效

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

  8. 如何用纯 CSS 创作炫酷的同心矩形旋转动画

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

  9. 如何用纯 CSS 创作一个渐变色动画边框

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

随机推荐

  1. Angular 项目开发中父子组件传参

    在项目开发中经常会遇到 组件之间传参的问题.今天总结下在使用angular的项目中父子组件传参的问题: 1.父组件向子组件传参: 然后在父组件中 然后在父组件的html中 然后就可以在子组件中使用了 ...

  2. 2018 年度码云热门项目排行榜 TOP 10

    2016 年度码云热门项目排行榜 TOP 10 是通过开源项目2016年在码云上的 Watch.Star.Fork 数量来评定的榜单.码云平台发展至今,涌现了越来越多优秀的开源项目,越来越多的开源作者 ...

  3. html 文本溢出显示省略号 .....

  4. Codeforces 1107G(dp)

    1.答案要取连续的区间疯狂暗示线段树. 2.外层枚举r,内层枚举l显然过于暴力. 3.考虑内层的优化.dp[i]:以第i位为结尾的答案(长度大于1的).dp[i] = max(第一种情况,第二种情况) ...

  5. Queue Sequence HDU - 4441

    码力不行啊... 错误记录: 171行后面对find2的使用错误,原来写的是p=find2(rt,p1),然后再加上一句能过样例但很假的特判 事实上,现在是要寻找最大的j,使得d2[1..j-1]=p ...

  6. Java GC基础

    Java的垃圾回收机制负责回收无用对象占据的内存资源,但是有特殊情况:假定对象不是使用new关键字获得了一块儿“特殊”的内存区域,

  7. SQL系列函数——数学函数

    1.abs函数取数值表达式的绝对值 ) 结果是40 2.ceiling函数取大于等于指定表达式的最小整数 select CEILING(40.5) 结果是41 3.floor函数取小于等于指定表达式的 ...

  8. MySQL日期处理

    一.MySQL 获得当前日期时间 函数1.1 获得当前日期+时间(date + time)函数:now()mysql> select now(); +---------------------+ ...

  9. AJPFX总结方法里的属性

    嵌套循环:循环里套循环 假设外循环的循环次数是m次,内循环的循环次数是n次,那么内层循环的循环次数需要 m * n次.   Eg:利用for循环语句的嵌套打印出乘法口诀表   class break1 ...

  10. mysql对库,表及记录的增删改查

    破解密码 #1.关闭mysqlnet stop mysqlmysql还在运行时需要输入命令关闭,也可以手动去服务关闭 #2.重新启动mysqld --skip-grant-tables跳过权限 #3m ...