发表日期: 2021-06-16 11:04:20 浏览次数:189
【网站建设】杭州网站制作-杭州网络公司-杭州网页设计-杭州网店美工-杭州网站开发
杭州,简称“杭”,古称临安、钱塘,是浙江省省会、副省级市、杭州都市圈核心城市,国务院批复确定的浙江省经济、文化、科教中心,长江三角洲中心城市之一 [1] 。全市共辖10个市辖区、1个县级市、2个县,总面积16853.57平方千米,建成区面积648.46平方千米,常住人口1193.60万人。 [2-3]
杭州地处中国华东地区、钱塘江下游、东南沿海、浙江北部、京杭大运河南端,是环杭州湾大湾区核心城市 [4] 、沪嘉杭G60科创走廊中心城市 [5] 、国际重要的电子商务中心 [6] 。杭州人文古迹众多,西湖及其周边有大量的自然及人文景观遗迹,具代表性的有西湖文化、良渚文化、丝绸文化、茶文化,以及流传下来的许多故事传说。
杭州自秦朝设县治以来已有2200多年的历史,中国著名的七大古都之一 [152] ,曾是吴越国和南宋的都城。因风景秀丽,素有“人间天堂”的美誉。杭州得益于京杭大运河和通商口岸的便利,以及自身发达的丝绸和粮食产业,历史上曾是重要的商业集散中心。后来依托沪杭铁路等铁路线路的通车以及上海在进出口贸易方面的带动,轻工业发展迅速。新世纪以来,随着阿里巴巴等高科技企业的带动,互联网经济成为杭州新的经济增长点。
2018年世界短池游泳锦标赛、2022年亚运会在杭州举办。2020年中国百强城市排行榜排第5位。 [7] 2019年6月未来网络试验设施开通运行。 [8] 11月29日,杭州直飞开罗航线正式开通。 [9] 2019年12月,《长江三角洲区域一体化发展规划纲要》将杭州定位为特大城市。 [10]
今天分享一个用 css3 来实现一个最近特别流行的故障风格的文字展示动画,我敢说,只要你在你的项目中用到这个动画,面试官看到了一定会眼前一亮。下面先来看一下成品图:
该动画效果就比较复杂了,用到的知识比较多,例如 「css伪元素 、元素自定义属性 、蒙版属性 、animation动画等等」
推荐阅读:在之前我也整过一篇关于CSS文字动画的内容,效果也不错,感兴趣的可以下去看看《酷炫的CSS文字动画特效》
<body> <div class="txt" data-text="我是故障风格的文字"> 我是故障风格的文字 </div> </body>
这里我们使用了自定义属性,即 data-
加上我们自定义的属性名,我们将我们的文字内容作为该属性的值,方便之后伪元素获取到对应的文字。
@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)
时,表示蒙版作用区域大小跟元素标签一样大,如下图所示(红色边框表示蒙版的作用区域)
此时我们的文字是可以完全展示出来的,因为蒙版的作用区域就是我们标签元素的大小
然后我们再来看一下,如果我们的设置为 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
,分别定位到跟父元素同样的位置,然后分别向左、右侧移一点点的距离,制作一个错位的效果,然后都将背景色设置为与父元素背景色一样的颜色,用于遮挡父元素。
然后设置了蒙版垂直变化动画以后,被蒙版遮挡的部分虽然看不到了,但是会露出下面一层的父元素内容,这样就可以实现了一个完美的故障风格的文字展示动画了。
备案号: 苏ICP备11067224号
CopyRight © 2011 书生商友信息科技 All Right Reserved
24小时服务热线:400-111-6878 E-MAIL:1120768800@qq.com QQ:1120768800
网址: https://www.768800.com 网站建设:上往建站
关键词: 网站建设| 域名邮箱| 服务器空间| 网站推广| 上往建站| 网站制作| 网站设计| 域名注册| 网络营销| 网站维护|
企业邮箱| 虚拟主机| 网络建站| 网站服务| 网页设计| 网店美工设计| 网站定制| 企业建站| 网站设计制作| 网页制作公司|
400电话办理| 书生商友软件| 葬花网| 调温纤维| 海洋馆运营维护| 北京保安公司| 殡仪馆服务| 殡葬服务| 昌平殡葬| 朝阳殡葬|
欢迎您免费咨询,请填写以下信息,我们收到后会尽快与您联系
服务热线:400-111-6878