文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

如何使用CSS实现毛玻璃特效

2023-06-29 19:10

关注

这篇文章主要介绍“如何使用CSS实现毛玻璃特效”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“如何使用CSS实现毛玻璃特效”文章能帮助大家解决问题。

一、backdrop-filter 是金手指吗?

毛玻璃效果在 iOS 系统上比较常见,比如消息通知栏、手机助手卡片等地方,所以咱打开苹果官网看看!

如何使用CSS实现毛玻璃特效

果不其然,导航栏就用到了“家族式设计”的“毛玻璃”特效

打开控制台抄一抄作业:

如何使用CSS实现毛玻璃特效

主要是用到了 backdrop-filter CSS3 的属性,于是乎,顺手就用上了。

主要的卡片 CSS 代码如下:

.card-backdrop-filter {    position: relative;    z-index: 1;    width: 600px;    height: 300px;    border-radius: 6px;    padding: 10px;    color: #fff;    font-size: 16px;    overflow: hidden;    margin: 100px auto;    backdrop-filter: blur(10px);    background-color: rgba(255,255,255,0.72);  }

在 Chrome 浏览器看着效果还可以:

如何使用CSS实现毛玻璃特效

然后再到某台老 Android 版本的移动端上看看,结果不行了!!!

去查了查兼容性:backdrop-filter -- caiuse

如何使用CSS实现毛玻璃特效

需要再寻求另外的方式,这里补充一下子,filter 可以理解为滤镜,backdrop-filter 就是给背景设置滤镜效果,CSS 目前支持的滤镜效果有

blur(): 模糊brightness(): 亮度contrast(): 对比度drop-shadow(): 阴影grayscale(): 灰度hue-rotate(): 色相旋转invert(): 反色opacity(): 透明度saturate(): 饱和度sepia(): 褐色

如果不考虑兼容性,backdrop-filter 会在不支持的浏览器上直接显示背景色,也就是失去设定的效果(“体验降级”)。

如果 UI 小姐姐和 PM 大哥能同意的话,也是非常推荐大家使用,毕竟谁不想早下班学习呐?

二、filter 试一试?

另一个设置模糊度的 CSS 属性就是 filter,那么我们的另一个思路就是通过 filter 来模拟 backdrop-filter 属性的效果。

filter 的兼容性会更好:filter -- caiuse

如何使用CSS实现毛玻璃特效

我们看看 filterbackdrop-filter 效果的差异:

.card-filter {  position: relative;  z-index: 1;  width: 600px;  height: 300px;  border-radius: 6px;  padding: 10px;  color: #fff;  font-size: 16px;  overflow: hidden;   margin: 100px auto;  filter: blur(10px);  background-color: rgba(255,255,255,0.72);}

如何使用CSS实现毛玻璃特效

这效果和实际的设计需求大相径庭,因此还需要改改!

三、filter 的组合拳

因为 filter 设置的是整个元素的模糊度,而不是做用于元素的背景容器,所以需要一个和卡片等大小的占位元素来单独设置模糊度,并作为背景元素。

3.1 ::before + 固定双背景图

这里偷个懒,直接使用了伪元素 ::before,实际场景为了考虑兼容性,建议大家还是用 div 块级元素占位

.card-filter::before {  content: ' ';  position: absolute;  top: 0;  right: 0;  bottom: 0;  left: 0;  z-index: -1;   filter: blur(10px);   background: url(http://p2.qhimg.com/bdr/__85/t01781bd4b1218329e1.jpg) no-repeat center fixed;  background-size: cover;}

这里注意到,卡片采用了和整个容器的背景图属性是一样的,通过 fixed 方式固定背景图,这样当元素在任意方向滚动的时候,背景图不会移动,能保证背景效果是一致的

3.2 利用 margin 属性的负值扩大容器

模糊度的效果如下图,还是有差异,因为 filter 是从容器外边框向内聚合的一个滤镜,导致滤镜外边框有一个白圈

如何使用CSS实现毛玻璃特效

此时只需要扩大 ::before 元素的容器大小,这里直接可使用 margin 属性负值扩大容器

.card-filter::before {  ...+ margin: -20px;}

此时的效果就有点“那个意思了”,看来快可以交差了

如何使用CSS实现毛玻璃特效

3.3 ::after 填补消失的背景色

原本设置在 .card-filter 类上的 background-color: rgba(255, 255, 255, 0.72); 没起作用!

因为 ::before 伪类作用于 .card-filter 元素内,是其子元素,又因为 ::beforebackground 属性设置了背景图,遮盖了父元素 .card-filter 的背景色。

知道了原因,那么我们就可以在 .card-filter 元素内再添加一个子元素(伪类),用于设置背景色!

再偷个懒,直接使用 ::after 伪类,就不用改造 DOM 结构。

.card-filter::after {  content: ' ';  position: absolute;  top: 0;  right: 0;  bottom: 0;  left: 0;  z-index: -1;  background-color: rgba(255, 255, 255, 0.72);}

此时,效果就和 backdrop-filter 的效果相同:

如何使用CSS实现毛玻璃特效

关于“如何使用CSS实现毛玻璃特效”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网行业资讯频道,小编每天都会为大家更新不同的知识点。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯