实现网页变灰效果
了解
我们先来看看各大主流网站是如何实现这种效果的。
- 阿里云
data:image/s3,"s3://crabby-images/e168f/e168f2d82c59f4e2815ae3e28aeac18e7dd6b66b" alt=""
- 腾讯云
data:image/s3,"s3://crabby-images/d1591/d1591522e707952e293e6ac55f64ff600fbf8436" alt=""
- BiliBili
data:image/s3,"s3://crabby-images/55553/55553fdd1ba58577985d738c6e1177f230a0a73d" alt=""
- 京东
data:image/s3,"s3://crabby-images/253b2/253b25ad42aef5fdde08aae0c13b0ddedc9e1505" alt=""
- 淘宝
data:image/s3,"s3://crabby-images/ba763/ba763422eefd75c005b86af89ef7e40a41384514" alt=""
- 掘金
data:image/s3,"s3://crabby-images/370fe/370fec79ec026f016918e22a4ade2bb8f7436346" alt=""
实现
我们可以发现它们实现的方式都是利用了 filter 属性。
CSS 属性 filter 将模糊或颜色偏移等图形效果应用于元素。滤镜通常用于调整图像、背景和边框的渲染。
综上所述,我们只要给页面的 html
设置这种样式即可变灰:
1 | html { |
我们还可以发现有些的代码写了很多行,比如京东。这是因为它对 filter
属性做了兼容。
完整版如下:
1 | html { |
扩展
filter
还有更多其他的属性:
1 | filter: blur() | brightness() | contrast() | drop-shadow() | grayscale() | hue-rotate() | invert() | opacity() | saturate() | sepia() | url(); |
这里就不一一介绍了,详情去前往 MDN - filter 查看。
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 LqZww's blog!
评论
ValineLivere