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解决移动页面上点击链接触发色块的问题
Jun 03 HTML / CSS
不同浏览器对CSS3和HTML5的支持状况
Oct 31 HTML / CSS
CSS3实现swap交换动画
Jan 19 HTML / CSS
详解CSS3浏览器兼容
Dec 14 HTML / CSS
html5中为audio标签增加停止按钮动作实现方法
Jan 04 HTML / CSS
html5播放视频且动态截图实现步骤与代码(支持safari其他未测试)
Jan 06 HTML / CSS
html5的画布canvas——画出简单的矩形、三角形实例代码
Jun 09 HTML / CSS
5 个强大的HTML5 API 函数推荐
Nov 19 HTML / CSS
使用phonegap创建联系人的实现方法
Mar 30 HTML / CSS
html5移动端价格输入键盘的实现
Sep 16 HTML / CSS
HTML5播放实现rtmp流直播
Jun 16 HTML / CSS
详解CSS不定宽溢出文本适配滚动
May 24 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清除数组中所有字符串两端空格的方法
2014/10/20 PHP
Codeigniter的dom类用法实例
2015/06/26 PHP
PHP快速排序quicksort实例详解
2016/09/28 PHP
VSCode+PHPstudy配置PHP开发环境的步骤详解
2020/08/20 PHP
jquery实现固定顶部导航效果(仿蘑菇街)
2013/03/21 Javascript
多种方式实现JS调用后台方法进行数据交互
2013/08/20 Javascript
AspNet中使用JQuery boxy插件的确认框
2015/05/20 Javascript
Vuex之理解Store的用法
2017/04/19 Javascript
React Js 微信禁止复制链接分享禁止隐藏右上角菜单功能
2017/05/26 Javascript
webpack4 入门最简单的例子介绍
2018/09/05 Javascript
JS 实现微信扫一扫功能
2018/09/14 Javascript
JS实现马赛克图片效果完整示例
2019/04/13 Javascript
JS中的算法与数据结构之栈(Stack)实例详解
2019/08/20 Javascript
jQuery实现弹幕特效
2019/11/29 jQuery
如何在微信小程序中存setStorage
2019/12/13 Javascript
[56:14]Fnatic vs OG 2018国际邀请赛小组赛BO2 第二场 8.18
2018/08/19 DOTA
python根据给定文件返回文件名和扩展名的方法
2015/03/27 Python
Python解析nginx日志文件
2015/05/11 Python
Python创建模块及模块导入的方法
2015/05/27 Python
python实现发送和获取手机短信验证码
2016/01/15 Python
python回调函数中使用多线程的方法
2017/12/25 Python
python实现机器人行走效果
2018/01/29 Python
Python学习笔记之变量、自定义函数用法示例
2019/05/28 Python
python编程进阶之异常处理用法实例分析
2020/02/21 Python
Python错误的处理方法
2020/06/23 Python
django下创建多个app并设置urls方法
2020/08/02 Python
Merrell美国官网:美国登山运动鞋品牌
2018/02/07 全球购物
全球知名的珠宝首饰品牌:Kay Jewelers
2018/02/11 全球购物
新西兰优惠网站:Treat Me
2019/07/04 全球购物
电子商务专业求职信
2014/03/08 职场文书
遗嘱公证书标准样本
2014/04/08 职场文书
租房协议书
2014/09/12 职场文书
2015年中秋放假通知范文
2015/08/18 职场文书
房产销售员2015年终工作总结
2015/10/22 职场文书
python实现层次聚类的方法
2021/11/01 Python
Sentry的安装、配置、使用教程(Sentry日志手机系统)
2022/07/23 Python