您现在的位置是:网站首页> 编程资料编程资料
利用CSS3实现毛玻璃效果示例源码_css3_CSS_网页制作_
2023-11-10
631人已围观
简介 相信大家都知道毛玻璃效果做的好的话,能使页面显得非常生动立体,整体效果非常好,下面我们就来学习下如何利用CSS3实现毛玻璃效果。
先来看看效果图

复制代码
代码如下:body {
min-height: 100vh;
box-sizing: border-box;
margin: 0;
padding-top: calc(50vh - 6em);
font: 150%/1.6 serif;
background: url("iphone.jpg") fixed 0 center;
background-size: cover;
}
main {
margin: 0 auto;
padding: 1em;
max-width: 30em;
border-radius: .3em;
box-shadow: 0 0 0 1px hsla(0,0%,100%,.3) inset,
0 .5em 1em rgba(0, 0, 0, 0.6);
text-shadow: 0 1px 1px hsla(0,0%,100%,.3);
background: hsla(0,0%,100%,.3);
}
去掉那些式样方面的代码,上面实现毛玻璃效果的核心代码如下:
复制代码
代码如下:body {
…
background: url("iphone.jpg") fixed 0 center;
background-size: cover;
}
main {
…
background: hsla(0,0%,100%,.3);
}
当然这个效果离我们的期望还有点距离,因为单纯的30%的透明度会让文字变的难以阅读。对页面来说背景图只是起美化作用,文字才是最核心的。你可以增大透明度的百分比,但这样页面会显得很死板。为了让文字便于阅读,又保持页面的生动活泼,可以对上面的mian标签的背景做模糊处理。
你可能尝试blur滤镜,但可惜的是效果不对:

复制代码
代码如下:main {
…
-webkit-filter: blur(3px);
filter: blur(3px);
}
用blur滤镜会将文字也模糊掉,更看不清了,只能放弃。正确的做法是给mian标签增加伪元素::before,在伪元素上使用blur滤镜:(为了效果演示,加上了红色背景色)

复制代码
代码如下:main {
position: relative;
…
}
main::before {
content: '';
position: absolute;
top: 0; right: 0; bottom: 0; left: 0;
z-index: -1;
-webkit-filter: blur(20px);
filter: blur(20px);
background: rgba(255,0,0,.5);
}
可以看出blur效果是出来了,但导致了两个问题。首先由于blur出现了外阴影,这个比较好解决,只要加上overflow: hidden;就行了。其次四周20px的模糊半径范围内模糊效果会逐渐消退。如果对此比较介意,想让四周的模糊效果和中间一样,可以将伪元素尺寸外扩20px,为了保险起见,可以稍微再外扩一点到30px:

复制代码
代码如下:main {
…
overflow: hidden;
}
main::before {
…
margin: -30px;
}
最后将伪元素的红色背景色替换成body的背景图即可,效果如下。

总结
以上就是CSS3实现毛玻璃效果的全部内容,希望能对大家的学习或者工作带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。
相关内容
- CSS3中动画属性transform、transition和animation属性的区别_css3_CSS_网页制作_
- DIV+CSS实现带三角箭头的提示框 _Div+CSS教程_CSS_网页制作_
- 全民小镇赚钱最高店铺和升级最快的建造介绍_手机游戏_游戏攻略_
- 全民小镇江南水乡怎么建设?全民小镇江南水乡建设技巧攻略 _手机游戏_游戏攻略_
- 全民小镇VIP各个等级的特权和花费介绍_手机游戏_游戏攻略_
- 刀塔传奇熊猫酒仙技能加点顺序解析_手机游戏_游戏攻略_
- 天天炫斗紫装礼包如何获得? 紫装礼包有什么奖励?_手机游戏_游戏攻略_
- 雷霆战机无尽快速刷宝箱灰烬秒杀4.28最新无异常无邮件图文教程_手机游戏_游戏攻略_
- 雷霆战机刷宝箱ios介绍 雷霆战机ios刷宝箱技巧攻略_手机游戏_游戏攻略_
- 天天酷跑世界对战没有搜寻到小伙伴怎么办?找不到小伙伴怎么回事?_手机游戏_游戏攻略_
