利用CSS3实现毛玻璃效果示例源码


Posted in HTML / CSS onSeptember 25, 2016

先来看看效果图

利用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);
}</p> <p><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实现毛玻璃效果示例源码

总结
以上就是CSS3实现毛玻璃效果的全部内容,希望能对大家的学习或者工作带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

HTML / CSS 相关文章推荐
修复iPhone的safari浏览器上submit按钮圆角bug
Dec 24 HTML / CSS
利用css3实现的简单的鼠标悬停按钮
Nov 04 HTML / CSS
CSS3实现淘宝留白的方法
Jun 05 HTML / CSS
HTML5 embed 标签使用方法介绍
Aug 13 HTML / CSS
html5定位并在百度地图上显示的示例
Apr 27 HTML / CSS
调用HTML5的Canvas API绘制图形的快速入门指南
Jun 17 HTML / CSS
使用canvas对多图片拼合并导出图片的方法
Aug 28 HTML / CSS
Canvas 像素处理之改变透明度的实现代码
Jan 08 HTML / CSS
详解使用postMessage解决iframe跨域通信问题
Nov 01 HTML / CSS
H5 video poster属性设置视频封面的方法
May 25 HTML / CSS
CSS font-variation 可变字体的魅力(实例详解)
Mar 03 HTML / CSS
使用 CSS 构建强大且酷炫的粒子动画效果
Aug 14 HTML / CSS
CSS3实现简易版的刮刮乐效果
Sep 27 #HTML / CSS
纯DOM+CSS3实现简单的小风车动画
Sep 27 #HTML / CSS
灵活运用CSS3特性绘制简易版围棋效果
Sep 28 #HTML / CSS
CSS3 media queries + jQuery实现响应式导航
Sep 30 #HTML / CSS
CSS3中的元素过渡属性transition示例详解
Nov 30 #HTML / CSS
CSS3 3D立方体效果示例-transform也不过如此
Dec 05 #HTML / CSS
前端制作动画的几种方式(css3,js)
Dec 12 #HTML / CSS
You might like
PHP中strtotime函数使用方法分享
2012/01/10 PHP
php微信公众平台开发之微信群发信息
2016/09/13 PHP
php微信公众平台开发(三)订阅事件处理
2016/12/06 PHP
laravel返回统一格式错误码问题
2019/11/04 PHP
Thinkphp 框架配置操作之动态配置、扩展配置及批量配置实例分析
2020/05/15 PHP
IE autocomplete internet explorer's autocomplete
2007/06/30 Javascript
javascript计算当月剩余天数(天数计算器)示例代码
2014/01/09 Javascript
JQuery插件ajaxfileupload.js异步上传文件实例
2015/05/19 Javascript
基于Jquery插件实现跨域异步上传文件功能
2016/04/26 Javascript
微信小程序 保留小数(toFixed)详细介绍
2016/11/16 Javascript
JS比较两个数值的大小实例
2016/11/25 Javascript
微信JS-SDK自定义分享功能实例详解【分享给朋友/分享到朋友圈】
2016/11/25 Javascript
Node之简单的前后端交互(实例讲解)
2017/11/14 Javascript
angularjs获取到My97DatePicker选中的值方法
2018/10/02 Javascript
python中使用pyhook实现键盘监控的例子
2014/07/18 Python
Python的Flask框架中@app.route的用法教程
2015/03/31 Python
django上传图片并生成缩略图方法示例
2017/12/11 Python
tensorflow训练中出现nan问题的解决
2018/02/10 Python
Python返回数组/List长度的实例
2018/06/23 Python
Python图像处理之简单画板实现方法示例
2018/08/30 Python
python按时间排序目录下的文件实现方法
2018/10/17 Python
python+mysql实现教务管理系统
2019/02/20 Python
Python实现去除图片中指定颜色的像素功能示例
2019/04/13 Python
python的turtle库使用详解
2019/05/10 Python
Pandas的read_csv函数参数分析详解
2019/07/02 Python
提升Python效率之使用循环机制代替递归函数
2019/07/23 Python
Python将列表中的元素转化为数字并排序的示例
2019/12/25 Python
Python 无限级分类树状结构生成算法的实现
2021/01/21 Python
兰兰过桥教学反思
2014/02/08 职场文书
《夸父追日》教学反思
2014/02/26 职场文书
2014年国庆节庆祝建国65周年比赛演讲稿
2014/09/21 职场文书
优秀党支部申报材料
2014/12/24 职场文书
2016年春节慰问信息
2015/03/25 职场文书
终止解除劳动合同证明书
2015/06/17 职场文书
Nginx中使用Lua脚本与图片的缩略图处理的实现
2022/03/18 Servers
简单聊一聊SQL注入及防止SQL注入
2022/03/23 MySQL