【转】请收下这72个炫酷的CSS技巧
1、前言
CSS是一门很特殊的语言,不像一般的编程语言那样需要抽象的思维和严密的逻辑,它真正需要的是想象力——将你脑中所想的意象用代码来表现出来。那么意象又是如何产生的呢?最常用的方法就是探索和观察。举个例子,笔者平时热爱看番,每看到有意思的场景画面总会下意识地记录下来,这对动画创作会非常有帮助;同样地,一旦笔者发现一个制作精良的网站,也会将网站上那些吸引人的元素仔细审查一遍,灵感也自然就有了。
演示网址1:codepen
演示网址2:shiroi
源码地址:github
本文的技巧将不会止步于72个。灵感不息,创作不止。
2、注意
2.1、兼容性
本文的所有技巧都未考虑兼容性,因为个人认为兼容性是一种束缚,它会妨碍你写出优秀的作品。如果硬是要考虑的话请自行解决,这个网站或许能帮到你。
2.2、框架
本文所用到的技巧皆是SCSS+TypeScript。如果想移植到React或Vue上的话请根据框架本身的特点自行适配。笔者不用这类框架的原因很简单:框架很容易就会过时,原生CSS+JS才是王道。
2.3、教程
笔者实在是不擅长写这类东西,不过倒是可以把常用的属性和模式列出来,供大家参考参考。
常用属性:猛戳这里
常用模式:猛戳这里
3、动画
3.1、利用不同的delay
实现交错动画
- Reveal Text
- Staggered Stair Loading
- Staggered Square Loading
- Staggered Wave Loading
- Gleaming Loading
- Particle Burst
- Gleaming Heading
- Staggered Shrinking Loading
- Snow
- Staggered Rise In Text
- Staggered LandIn Text
4、文本
4.1、利用background-clip:text
配合color
实现渐变文字效果
4.2、利用动态hsl
颜色实现彩虹文字效果
4.3、利用text-shadow
实现发光文字效果
4.4、利用text-shadow
实现伪3D文字效果
4.5、利用web animation
实现冒泡文字效果
4.6、利用动态max-width
实现文本展开效果
4.7、利用绝对定位、3D变换和JS实现翻转文字
5、视觉
5.1、利用backdrop-filter
实现毛玻璃背景效果
5.2、利用背景、绝对定位和filter
实现毛玻璃景深效果
5.3、利用blur
和contrast
滤镜实现融合效果
5.4、利用元素叠加blur
滤镜实现日光效果
- Eclipse Loader
- Glowing List Hover
- Glowing Gradient Border
- Glowing Gradient Button
- Crimson Crescent Loading
5.5、利用mix-blend-mode:screen
实现文本遮罩效果
5.6、利用-webkit-box-reflect
实现倒影效果
6、页面
6.1、利用3D变换实现视差效果
6.2、利用position:sticky
实现粘性滚动效果
6.3、利用绝对定位和交错动画实现镜头拉伸背景效果
6.4、利用伪元素、绝对定位和动画实现滑动幻灯片
7、组件
7.1、利用border-radius
实现曲边导航栏
7.2、利用动画和绝对定位实现汉堡菜单
7.3、利用伪元素和动画实现动态划线效果
- Menu Hover Underline
- Menu Hover Magnify
- Button Hover Border Stroke With Float Text
- Header With Slide Bar
- Button Hover Multiple Border Stroke