今天分享一个用 css3 来实现一个最近特别流行的故障风格的文字展示动画,我敢说,只要你在你的项目中用到这个动画,面试官看到了一定会眼前一亮。下面先来看一下成品图

该动画效果就比较复杂了,用到的知识比较多,例如 css伪元素 、元素自定义属性 、蒙版属性 、animation动画等等

标签元素部分

<body><div class="txt" data-text="我是故障风格的文字">我是故障风格的文字</div>
</body>

这里我们使用了自定义属性,即 data- 加上我们自定义的属性名,我们将我们的文字内容作为该属性的值,方便之后伪元素获取到对应的文字

@keyframes部分

@keyframes animation-before{0% {clip-path: inset(0 0 0 0);}5% {clip-path: inset(.8em 0 .4em 0);}10% {clip-path: inset(.4em 0 .8em 0);}15% {clip-path: inset(.1em 0 1em 0);}20% {clip-path: inset(.3em 0 .6em 0);}25% {clip-path: inset(.6em 0 .3em 0);}30% {clip-path: inset(.8em 0 .5em 0);}35% {clip-path: inset(1em 0 .1em 0);}40% {clip-path: inset(.7em 0 .35em 0);}45% {clip-path: inset(.5em 0 .2em 0);}50% {clip-path: inset(.2em 0 .5em 0);}55% {clip-path: inset(.35em 0 .7em 0);}60% {clip-path: inset(.1em 0 .9em 0);}65% {clip-path: inset(.8em 0 .46em 0);}70% {clip-path: inset(.66em 0 .33em 0);}75% {clip-path: inset(.48em 0 .23em 0);}80% {clip-path: inset(.23em 0 .48em 0);}85% {clip-path: inset(.39em 0 .79em 0);}90% {clip-path: inset(.33em 0 .66em 0);}95% {clip-path: inset(1em 0 .3em 0);}100% {clip-path: inset(.62em 0 .29em 0);}
}
@keyframes animation-after{0% {clip-path: inset(0 0 0 0);}5% {clip-path: inset(.4em 0 .8em 0);}10% {clip-path: inset(.8em 0 .4em 0);}15% {clip-path: inset(1em 0 .1em 0);}20% {clip-path: inset(.6em 0 .3em 0);}25% {clip-path: inset(.3em 0 .6em 0);}30% {clip-path: inset(.5em 0 .8em 0);}35% {clip-path: inset(.1em 0 1em 0);}40% {clip-path: inset(.35em 0 .7em 0);}45% {clip-path: inset(.2em 0 .5em 0);}50% {clip-path: inset(.5em 0 .2em 0);}55% {clip-path: inset(.7em 0 .35em 0);}60% {clip-path: inset(.9em 0 .1em 0);}65% {clip-path: inset(.46em 0 .8em 0);}70% {clip-path: inset(.3em 0 .66em 0);}75% {clip-path: inset(.23em 0 .48em 0);}80% {clip-path: inset(.48em 0 .23em 0);}85% {clip-path: inset(.79em 0 .39em 0);}90% {clip-path: inset(.66em 0 .33em 0);}95% {clip-path: inset(.3em 0 1em 0);}100% {clip-path: inset(.29em 0 .62em 0);}
}

这里我们设置了两个keyframes,分别为 animation-beforeanimation-after

想必已经很明显了,前者是准备给我们后面的伪元素 before 使用的 ;后者是给我们后面的伪元素 after 使用的

那么其中用到的 clip-path 是干什么用的呢?这个是css3的一个新属性,叫做蒙版,而其中的 inset() 值表示的是蒙版形状为矩形

我们来看一下它的用法

首先 inset() 接收四个长度参数,分别表示蒙版距离元素标签的上侧右侧下侧左侧的距离,从而决定了蒙版的大小

当我们设置为 inset(0 0 0 0)时,表示蒙版作用区域大小跟元素标签一样大,如下图所示(红色边框表示蒙版的作用区域)

此时我们的文字是可以完全展示出来的,因为蒙版的作用区域就是我们标签元素的大小

然后我们再来看一下,如果我们的设置为 inset(30px 0 0 0) ,则测试表示,蒙版的作用区域距离标签元素的上侧 30px,距离其它的边 0px,如图所示

图中蓝色边框的部分不是蒙版的作用区域,因此我们无法看到该区域的内容,真实情况如下图所示

在了解了蒙版的使用情况了以后,我们就通过 @keyframes 来设置逐帧动画,使蒙版的作用区域在垂直方向一直变化,实现上下抖动的效果,代码就如上所述

具体样式

body{height: 100vh;display: flex;justify-content: center;align-items: center;background: black;
}
.txt{display: inline-block;font-size: 65px;font-weight: 600;padding: 0 4px;color: white;position: relative;
}
.txt::before{/* 获取文本 */content: attr(data-text);position: absolute;/* 向左侧移2px */left: -2px;width: 100%;/* 将背景色设为与主背景同样的颜色,用于遮挡我们的标签元素 */background: black;/* 给before伪元素的文本添加左侧2px大小的红色文字阴影 */text-shadow:2px 0 red;/* 应用蒙版垂直变化动画,并一直循环 */animation: animation-before 3s infinite linear alternate-reverse;
}
.txt::after{/* 获取文本 */content: attr(data-text);position: absolute;/* 向左侧移2px */left: 2px;width: 100%;/* 将背景色设为与主背景同样的颜色,用于遮挡我们的标签元素 */background: black;/* 给before伪元素的文本添加右侧2px大小的蓝色文字阴影 */text-shadow: -2px 0 blue;/* 应用蒙版垂直变化动画,并一直循环 */animation: animation-after 3s infinite linear alternate-reverse;
}

这里,我们设置了两个伪元素 before 和 after,分别定位到跟父元素同样的位置,然后分别向左、右侧移一点点的距离,制作一个错位的效果,然后都将背景色设置为与父元素背景色一样的颜色,用于遮挡父元素。

然后设置了蒙版垂直变化动画以后,被蒙版遮挡的部分虽然看不到了,但是会露出下面一层的父元素内容,这样就可以实现了一个完美的故障风格的文字展示动画了。

强烈推荐

给你们推荐一下我的个人博客,拥有大量优质文章、面试宝典、算法精选,欢迎访问~

【css炫酷动画】让面试官眼前一亮的故障风格文字动画相关推荐

  1. 纯html+css炫酷地球仪动画效果

    纯html+css炫酷地球仪动画效果 <!DOCTYPE html> <html lang="en"> <head><meta chars ...

  2. 什么样的项目经历会让面试官眼前一亮

    很多同学都问过我类似的问题: 咱们<C语言也能干大事>中讲的自己动手写windows优化大师.自己动手写计算器等东西只是写着玩的小玩具而已,这些能用来以后找工作时写到简历中的作品吗?看别人 ...

  3. system流怎么判断为空_面试时被问到单例模式,怎么回答才能让面试官眼前一亮?...

    考虑到马上到来的金九银十的面试季,我给大家介绍一下面试官的必问题,先从单例模式开始,这个设计模式看似简单,想回答得让面试官眼前一亮,还不是那么容易的. 一.什么是单例模式 单例模式是一种常用的软件设计 ...

  4. 吐血整理的 Android 性能优化思维导图,让面试官眼前一亮

    引言 现如今 Android 开发行业的主要问题是因为初级的 Android 开发者太多了,导致初级开发的市场过于饱和,所以也就进一步导致初级和中级的开发者面临更大的竞争,因此想要脱离这种竞争现状,只 ...

  5. 从酷家乐面试官到收获阿里Offer过程中的一些心得与思考

    本文来自读者投稿,作者:绯凡,跟大家聊聊从酷家乐面试官到收获阿里 Offer 过程中的一些心得与思考,希望对大家的格局和理解有些帮助 https://juejin.im/post/5e842e6c51 ...

  6. HTML+CSS炫酷彩色立方体特效

    源码视频教程 HTML+CSS炫酷彩色立方体 HTML代码 <!DOCTYPE html> <html lang="en"><head>< ...

  7. wordpress字体样式——css炫酷的字体样式实现

    demo1:css实现颜色变化 效果如图所示 实现代码如下 <!DOCTYPE html> <html lang="en"> <head>< ...

  8. 串口发送tcp数据 源端口号_三分钟基础知识:用动画给面试官解释 TCP 三次握手过程...

    作者 |  小鹿 来源 |  小鹿动画学编程 写在前边 TCP 三次握手过程对于面试是必考的一个,所以不但要掌握 TCP 整个握手的过程,其中有些小细节也更受到面试官的青睐. 对于这部分掌握以及 TC ...

  9. 存在就不插入_动画:面试官问我插入排序和冒泡排序哪个更牛逼?

    来自公众号:小鹿动画学编程 写在前边 排序对于每个开发者来讲,都多多少少知道几个经典的排序算法,比如我们之前以动画形式分享的冒泡排序,也包括今天要分享的插入排序.还有一些其他经典的排序,小鹿整理的共有 ...

最新文章

  1. 领导和管理?你一定要分得清!
  2. BCB 编写 DLL 终极手册
  3. Oracle 原理: 闪回 flashback
  4. 程序员面试100题之十四:强大的和谐
  5. 主页被篡改修正方法(续)
  6. Google Analytics使用说明
  7. 【CodeForces - 523C】Name Quest (模拟)
  8. Python Base64模块的使用
  9. 面试题:在O(1)空间复杂度范围内对一个数组中前后连段有序数组进行归并排序...
  10. 【ArcPy视频教程】基于 ArcGIS Pro 的 ArcPy 教程(录制中)
  11. openwrt1907 mt7621配置DDR自适应
  12. 图片像素低,图片模糊怎么变清晰?
  13. ES中 minimum_should_match 的用法和误区
  14. ASP.NET MVC Liu_Cabbage 个人博客
  15. 如何在CSDN上删除博客、删除自己上传的资源
  16. Sketch 插件导出切片
  17. 2018 年最流行的十大编程语言,Java 无可争议!
  18. PS动作一键设计数字科技未来海报效果
  19. 嵌入式开发|嵌入式软件框架《一》常用的软件框架介绍与选择
  20. Mac干货 如何快速的在Mac上安装Windows双系统?虚拟机Parallels Desktop +Bootcamp安装

热门文章

  1. 爬取点评成都数据,只为告诉你哪家火锅最好吃
  2. linux 输入密码命令,linux密码口令命令passwd
  3. 快速了解:“华为的 HMS、鸿蒙系统” 和 “谷歌的 GMS”
  4. 中国软件网 给大家拜年啦:辞旧迎新,新春喜乐!
  5. 测试人生 | 从小团队的业务到独角兽的测开,涨薪超过60%,90后小哥哥凤凰涅槃了
  6. 怎么查看mysql密码
  7. npm -- 如何在本地安装npm npm 相关命令 本地使用命令行搭建一个 vue 工程
  8. c++实现strcpy函数
  9. 理解苹果App审核机制:只当守门员,不当裁判员
  10. 查看3306端口被谁占用