CSS的常用套路

1、交错动画

有时候,我们需要给多个元素添加同一个动画,播放后,不难发现它们会一起运动,一起结束,这样就会显得很平淡无奇。
那么如何将动画变得稍微有趣一点呢?很简单,既然它们都是同一时刻开始运动的,那么让它们不在同一时刻运动不就可以了吗。如何让它们不在同一时刻运动呢?注意到CSS动画有延迟( delay )这一属性。
举个栗子,比如有十个元素播放十个动画,将第二个元素的动画播放时间设定为比第一个元素晚0.5秒(也就是将延迟设为0.5秒),其他元素以此类推,这样它们就会错开来,形成一种独特的视觉效果。
这就是所谓的交错动画:通过设置不同的延迟时间,达到动画交错播放的效果。
本demo地址: https://codepen.io/alphardex/pen/XWWWBmQ

2、用JS分割文本

还有一种经常用到的玩法:用JS将句子或单词分割成字母,并给每个字母加上不同延时的动画,同样也很华丽。
本demo地址: https://codepen.io/alphardex/full/KKwvKGY
一般我们都是从第一个元素开始交错的。但如果要从中间元素开始交错的话,就要给当前元素的延时各加上一个值,这个值就是中间元素的下标到当前元素的下标的距离(也就是下标之差的绝对值)与步长的乘积,即: delay + Math.abs(i - middle) * step ,其中中间元素的下标 middle = letters.filter(e => e !== "").length / 2
本demo地址: https://codepen.io/alphardex/full/eYYMYXJ
所有有交错特性的动画都在这儿

3、随机粒子动画

说到随机性,我们可以实现一种更疯狂的效果:给几百个粒子添加交错动画,并且交错时间随机,位置大小也都是随机。如此一来我们就能用纯CSS模拟出下雪的效果。
又到了白色相簿的季节呢~为什么你写CSS这么熟练啊?
本demo地址: https://codepen.io/alphardex/full/dyPorwJ

伪类和伪元素

4、伪类

HTML元素的状态是可以动态变化的。举个栗子,当你的鼠标悬浮到一个按钮上时,按钮就会变成“悬浮”状态,这时我们就可以利用伪类 :hover 来选中这一状态的按钮,并对其样式进行改变。
:hover 是笔者最最常用的一个伪类。还有一个很常用的伪类是 :nth-child ,用于选中元素的某一个子元素。其他的类似 :focus:focus-within 等也有一定的使用。
本demo地址: https://codepen.io/alphardex/pen/pooYKVa

5、绝对定位实现多重边框

谁规定按钮只能有一套边框的?利用绝对定位和 padding ,我们可以给按钮做出3套大小不一的边框来,这样效果更炫了。
本demo地址: https://codepen.io/alphardex/full/ZEYXomW

6、伪元素

简而言之,伪元素就是在原先的元素基础上插入额外的元素,而且这个元素不充当HTML的标签,这样就能保持HTML结构的整洁。
我们知道每个元素都有 ::before::after 这两个伪元素,也就是说每个元素都提供了3个矩形(元素本身1个,伪元素2个)来供我们进行形状的绘制。现在又有了 clip-path 这个属性,几乎任意的形状都可以被绘制出来,全凭你的想象力
上面的动图是条子划过文本的动画,条子就是每个文本所对应的伪元素,对每个文本和其伪元素应用动画,就能达到上图的效果了
本demo地址: https://codepen.io/alphardex/pen/jOEOEzZ

7、attr()生成文本内容

元素可以有自定义的属性值,它的命名格式通常为 data-*
attr() 用于获取元素的这种自定义属性值,并赋值给其伪元素的 content 作为其生成的内容
利用这个函数,我们可以用伪元素在原先文本的基础上“复制”出另一个文本,如下图所示。
看上去有点乱糟糟的对吧?没事,给它加上 overflow: hidden ,把多余的文本遮住。通过JS分割文本并应用交错动画,就得到了如下的效果,这也是接下来本文要讲的 overflow 障眼法。
本demo地址: https://codepen.io/alphardex/full/wvBeXjd
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值