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


这篇文章主要介绍“如何使用CSS实现毛玻璃特效”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“如何使用CSS实现毛玻璃特效”文章能帮助大家解决问题。毛玻璃效果在 iOS 系统上比较常见,比如消息通知栏、手机助手卡片等地方,所以咱打开苹果官网看看!果不其然,导航栏就用到了“家族式设计”的“毛玻璃”特效打开控制台抄一抄作业:主要是用到了 backdrop-filter CSS3 的属性,于是乎,顺手就用上了。主要的卡片 CSS 代码如下:在 Chrome 浏览器看着效果还可以:然后再到某台老 Android 版本的移动端上看看,结果不行了!!!去查了查兼容性:backdrop-filter — caiuse需要再寻求另外的方式,这里补充一下子,filter 可以理解为滤镜,backdrop-filter 就是给背景设置滤镜效果,CSS 目前支持的滤镜效果有如果不考虑兼容性,backdrop-filter 会在不支持的浏览器上直接显示背景色,也就是失去设定的效果(“体验免费云主机域名降级”)。如果 UI 小姐姐和 PM 大哥能同意的话,也是非常推荐大家使用,毕竟谁不想早下班学习呐?另一个设置模糊度的 CSS 属性就是 filter,那么我们的另一个思路就是通过 filter 来模拟 backdrop-filter 属性的效果。且 filter 的兼容性会更好:filter — caiuse我们看看 filterbackdrop-filter 效果的差异:这效果和实际的设计需求大相径庭,因此还需要改改!因为 filter 设置的是整个元素的模糊度,而不是做用于元素的背景容器,所以需要一个和卡片等大小的占位元素来单独设置模糊度,并作为背景元素。3.1 ::before + 固定双背景图这里偷个懒,直接使用了伪元素 ::before,实际场景为了考虑兼容性,建议大家还是用 div 块级元素占位这里注意到,卡片采用了和整个容器的背景图属性是一样的,通过 fixed 方式固定背景图,这样当元素在任意方向滚动的时候,背景图不会移动,能保证背景效果是一致的3.2 利用 margin 属性的负值扩大容器模糊度的效果如下图,还是有差异,因为 filter 是从容器外边框向内聚合的一个滤镜,导致滤镜外边框有一个白圈此时只需要扩大 ::before 元素的容器大小,这里直接可使用 margin 属性负值扩大容器此时的效果就有点“那个意思了”,看来快可以交差了3.3 ::after 填补消失的背景色原本设置在 .card-filter 类上的 background-color: rgba(255, 255, 255, 0.72); 没起作用!因为 ::before 伪类作用于 .card-filter 元素内,是其子元素,又因为 ::beforebackground 属性设置了背景图,遮盖了父元素 .card-filter 的背景色。知道了原因,那么我们就可以在 .card-filter 元素内再添加一个子元素(伪类),用于设置背景色!再偷个懒,直接使用 ::after 伪类,就不用改造 DOM 结构。此时,效果就和 backdrop-filter 的效果相同:关于“如何使用CSS实现毛玻璃特效”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注百云主机行业资讯频道,小编每天都会为大家更新不同的知识点。

相关推荐: CSS3中的新特性::target-text选择器怎么用

这篇文章主要介绍了CSS3中的新特性::target-text选择器怎么用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇CSS3中的新特性::target-text选择器怎么用文章都会有所收获,下面我们一起来看看吧。想必大家都用过…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

Like (0)
Donate 微信扫一扫 微信扫一扫
Previous 05/22 10:13
Next 05/22 10:13

相关推荐