CSS3 毛玻璃效果


Posted in HTML / CSS onAugust 14, 2019

毛玻璃效果做的好能使页面显得非常生动立体。直接上图

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滤镜,但可惜的是效果不对:

CSS3 毛玻璃效果

main {
    …
    -webkit-filter: blur(3px);
    filter: blur(3px);
}

用blur滤镜会将文字也模糊掉,更看不清了,只能放弃。正确的做法是给mian标签增加伪元素::before,在伪元素上使用blur滤镜:(为了效果演示,加上了红色背景色)

CSS3 毛玻璃效果

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:

CSS3 毛玻璃效果

main {
    …
    overflow: hidden;
}
main::before {
    …
    margin: -30px;
}

最后将伪元素的红色背景色替换成body的背景图即可,效果如下。你也可以点击 这里 ,右键查看完整的源代码。

CSS3 毛玻璃效果

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

HTML / CSS 相关文章推荐
css3 background属性调整增强介绍
Dec 18 HTML / CSS
在HTML5中如何使用CSS建立不可选的文字
Oct 17 HTML / CSS
css3的focus-within选择器的使用
May 11 HTML / CSS
html5音频_动力节点Java学院整理
Aug 22 HTML / CSS
html5文字阴影效果text-shadow使用示例
Jul 25 HTML / CSS
基于html5 DeviceOrientation 实现微信摇一摇功能
Sep 25 HTML / CSS
html5 canvas绘制矩形和圆形的实例代码
Jun 16 HTML / CSS
HTML5和CSS3实例教程总结(推荐)
Jul 18 HTML / CSS
用canvas画心电图的示例代码
Sep 10 HTML / CSS
amazeui模态框弹出后立马消失并刷新页面
Aug 19 HTML / CSS
浅析HTML5 Landmark
Sep 11 HTML / CSS
css3中transform属性实现的4种功能
Aug 07 HTML / CSS
详解css position 5种不同的值的用法
Jul 30 #HTML / CSS
CSS Houdini实现动态波浪纹效果
Jul 30 #HTML / CSS
使用css实现android系统的loading加载动画
Jul 25 #HTML / CSS
使用CSS3实现input多选框自定义样式的方法示例
Jul 19 #HTML / CSS
详解css3中 text-fill-color属性
Jul 08 #HTML / CSS
解决margin 外边距合并问题
Jul 03 #HTML / CSS
css3实现蒙版弹幕功能
Jun 18 #HTML / CSS
You might like
整合了前面的PHP数据库连接类~~做成一个分页类!
2006/11/25 PHP
Yii PHP Framework实用入门教程(详细介绍)
2013/06/18 PHP
php读取本地json文件的实例
2018/03/07 PHP
javascript之ESC(第二类混淆)
2007/05/06 Javascript
用js实现的自定义的对话框的实现代码
2010/03/21 Javascript
JS 控制小数位数的实现代码
2011/08/02 Javascript
ASP.NET jQuery 实例1(在TextBox里面创建一个默认提示)
2012/01/13 Javascript
解决JS浮点数运算出现Bug的方法
2013/03/12 Javascript
将nodejs打包工具整合到鼠标右键的方法
2013/05/11 NodeJs
Javascript alert消息换行的方法
2013/08/07 Javascript
js关闭浏览器窗口及检查浏览器关闭事件
2013/09/03 Javascript
用C/C++来实现 Node.js 的模块(一)
2014/09/24 Javascript
jquery无限级联下拉菜单简单实例演示
2015/11/23 Javascript
DIV随滚动条滚动而滚动的实现代码【推荐】
2016/04/12 Javascript
Bootstrap实现下拉菜单效果
2016/04/29 Javascript
jquery自定义表单验证插件
2016/10/12 Javascript
详解vue 计算属性与方法跟侦听器区别(面试考点)
2018/04/23 Javascript
vue3.0 CLI - 2.3 - 组件 home.vue 中学习指令和绑定
2018/09/14 Javascript
微信小程序实现通过双向滑动缩放图片大小的方法
2018/12/30 Javascript
微信小程序 授权登录详解(附完整源码)
2019/08/23 Javascript
vue 单页应用和多页应用的优劣
2020/10/22 Javascript
[00:48]DOTA2国际邀请赛公开赛报名开始 扫码开启逐梦之旅
2018/06/06 DOTA
python进阶教程之循环对象
2014/08/30 Python
python下paramiko模块实现ssh连接登录Linux服务器
2015/06/03 Python
python安装twisted的问题解析
2018/08/21 Python
Django如何简单快速实现PUT、DELETE方法
2019/07/24 Python
pytorch神经网络之卷积层与全连接层参数的设置方法
2019/08/18 Python
使用Numpy对特征中的异常值进行替换及条件替换方式
2020/06/08 Python
收银员的岗位职责范本
2014/02/04 职场文书
手术室护士长竞聘书
2014/03/31 职场文书
投标文件签署授权委托书范本
2014/10/12 职场文书
市场部经理岗位职责
2015/02/02 职场文书
经典爱情感言
2015/08/03 职场文书
2019年聘任书的写作格式及范文!
2019/07/03 职场文书
Django+Celery实现定时任务的示例
2021/06/23 Python
使用 Apache 反向代理的设置技巧
2022/01/18 Servers