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

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

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


d6f1fc6dce75347a36732f309fc0b151.jpg


该动画效果就比较复杂了,用到的知识比较多,例如 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-before animation-after


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


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


      我们来看一下它的用法


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


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


      bec038487ff29caf5c267c9d01b5828e.png


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


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


      65d363df93469b9e6c656b6071d9910a.png


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


      56a39a7dc9d3b82a69f17b5b696e0f60.png


      在了解了蒙版的使用情况了以后,我们就通过 @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炫酷动画

        相关文章
        |
        前端开发 JavaScript
        CSS 过渡和动画
        CSS过渡和动画是用于为网页元素添加动态效果的两种重要技术
        641 143
        |
        9月前
        |
        自然语言处理 前端开发 JavaScript
        用 通义灵码 一键生成“水波纹按钮”,连 CSS 动画都不用自己写了!
        通义灵码是一款智能编程辅助工具,它可以根据自然语言指令自动生成高质量的代码。例如,只需输入“生成一个按钮,点击时带水波纹动画,模拟 Material Ripple 效果”,它就能生成具备完整交互逻辑、CSS 动画和良好性能的按钮组件。不仅如此,它还支持拓展功能,如长按触发提示、添加图标等,并能自动优化样式适配不同场景。通过通义灵码,开发者可以大幅提升效率,专注于创意实现,而不必纠结于繁琐的代码细节。
        |
        6月前
        |
        前端开发 算法 Java
        【CSS】前端三大件之一,如何学好?从基本用法开始吧!(九):强势分析Animation动画各类参数;从播放时间、播放方式、播放次数、播放方向、播放状态等多个方面,完全了解CSS3 Animation
        Animation属性 css3为Animation动画提供的几个属性如下: 属性名 属性值 animation-name 指定动画名称,该属性指定一个已有的关键帧定义。 animation-duration 指定动画持续时间。 animation-timing-funtion 指定动画变化速度。 animation-delay 指定动画延迟多长时间才开始执行。 animation-iteration-count 指定动画的循环执行次数。 animation:这是一个复合属性。
        416 3
        |
        9月前
        |
        前端开发
        文字显示在div 最下面,css怎么写
        文字显示在div 最下面,css怎么写
        601 0
        css3 svg制作404页面动画效果HTML源码
        css3 svg制作404页面动画效果HTML源码
        283 34
        jQuery+CSS3实现404背景游戏动画源码
        jQuery+CSS3实现404背景游戏动画源码
        248 22
        |
        Web App开发 移动开发 JavaScript
        纯CSS3+SVG实现的节日庆祝五彩纸屑动画效果源码
        这是一款基于纯CSS3+SVG实现的节日庆祝五彩纸屑动画效果源码。画面中左下角是一个圆锥形礼炮卡通效果,呈现出节日庆祝时礼花爆破、五彩纸屑纷飞的动画特效。整体动画效果采用纯css3+svg实现,没有引入任何外部图形或js脚本元素。建议使用支持HTML5与css3效果较好的火狐(Firefox)或谷歌(Chrome)等浏览器预览本源码。
        323 6
        |
        前端开发
        面试官让你使用CSS画一个圆,你会吗?
        面试官让你使用CSS画一个圆,你会吗?
        227 0
        面试官让你使用CSS画一个圆,你会吗?

        热门文章

        最新文章

      • 1
        【CSS】前端三大件之一,如何学好?从基本用法开始吧!(九):强势分析Animation动画各类参数;从播放时间、播放方式、播放次数、播放方向、播放状态等多个方面,完全了解CSS3 Animation
        416
      • 2
        【CSS】前端三大件之一,如何学好?从基本用法开始吧!(八):学习transition过渡属性;本文学习property模拟、duration过渡时间指定、delay时间延迟 等多个参数
        326
      • 3
        【CSS】前端三大件之一,如何学好?从基本用法开始吧!(七):学习ransform属性;本文学习 rotate旋转、scale缩放、skew扭曲、tanslate移动、matrix矩阵 多个参数
        296
      • 4
        (CSS)使用Flex布局,帮助你快速了解各种基本的Flex布局属性以及帮你让元素快速达到布局中的指定位置!
        202
      • 5
        【CSS】前端三大件之一,如何学好?从基本用法开始吧!(六):全方面分析css的Flex布局,从纵、横两个坐标开始进行居中、两端等元素分布模式;刨析元素间隔、排序模式等
        416
      • 6
        【CSS】前端三大件之一,如何学好?从基本用法开始吧!(五):背景属性;float浮动和position定位;详细分析相对、绝对、固定三种定位方式;使用浮动并清除浮动副作用
        608
      • 7
        【CSS】前端三大件之一,如何学好?从基本用法开始吧!(四):元素盒子模型;详细分析边框属性、盒子外边距
        760
      • 8
        【CSS】前端三大件之一,如何学好?从基本用法开始吧!(三):元素继承关系、层叠样式规则、字体属性、文本属性;针对字体和文本作样式修改
        212
      • 9
        【CSS】前端三大件之一,如何学好?从基本用法开始吧!(二):CSS伪类:UI伪类、结构化伪类;通过伪类获得子元素的第n个元素;创建一个伪元素展示在页面中;获得最后一个元素;处理聚焦元素的样式
        615
      • 10
        【CSS】前端三大件之一,如何学好?从基本用法开始吧!(一):CSS发展史;CSS样式表的引入;CSS选择器使用,附带案例介绍
        370