加入收藏 | 设为首页 | 会员中心 | 我要投稿 聊城站长网 (https://www.0635zz.com/)- 智能语音交互、行业智能、AI应用、云计算、5G!
当前位置: 首页 > 综合聚焦 > 编程要点 > 语言 > 正文

用CSS3怎样实现毛玻璃效果,代码指的是什么?

发布时间:2023-08-10 14:09:27 所属栏目:语言 来源:
导读: 这篇文章给大家分享的是用CSS3实现毛玻璃效果的内容,小编觉得挺实用的,能使得页面很生动,美化网页,因此分享给大家做个参考,文中示例代码介绍的很详细,感兴趣的朋友接下来一起跟随小编看看吧。

body {
 这篇文章给大家分享的是用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);
 
}
 
<main>……</main>
 
    去掉那些式样方面的代码,上面实现毛玻璃效果的核心代码如下:
 
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的背景图即可,效果如下。你也可以点击 这里 ,右键查看完整的源代码。
 
 

(编辑:聊城站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章