利用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 相关文章推荐
CSS3的Border-radius轻松制作圆角
Dec 24 HTML / CSS
8款精美的CSS3表单设计(登录表单/下拉选择/按钮附演示及源码)
Feb 04 HTML / CSS
html5 分层屏幕适配的方法
Mar 16 HTML / CSS
字中字效果的实现【html5实例】
May 03 HTML / CSS
利用canvas实现图片压缩的示例代码
Jul 17 HTML / CSS
HTML实现代码雨源码及效果示例
Feb 25 HTML / CSS
amazeui树节点自动展开折叠面板并选中第一个树节点的实现
Aug 24 HTML / CSS
CSS实现漂亮的时钟动画效果的实例代码
Mar 30 HTML / CSS
CSS3 制作精美的定价表
Apr 06 HTML / CSS
HTML中实现音乐或视频自动播放案例详解
May 30 HTML / CSS
html5+实现plus.io进行拍照和图片等获取
Jun 01 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
Linux下进行MYSQL编程时插入中文乱码的解决方案
2007/03/15 PHP
PHP排序算法类实例
2015/06/17 PHP
PHP网站自动化配置的实现方法(必看)
2017/05/27 PHP
使用JS进行目录上传(相当于批量上传)
2010/12/05 Javascript
常用jQuery代码分享
2015/07/14 Javascript
Bootstrap Fileinput文件上传组件用法详解
2016/05/10 Javascript
jQuery Easyui datagrid editor为combobox时指定数据源实例
2016/12/19 Javascript
JavaScript数据结构之链表的实现
2017/03/19 Javascript
如何使用Bootstrap创建表单
2017/03/29 Javascript
vue接入腾讯防水墙代码
2019/05/07 Javascript
Webpack 4如何动态切割JS注入文件名详解
2019/07/09 Javascript
使用layui日期控件laydate对开始和结束时间进行联动控制的方法
2019/09/06 Javascript
JS变量提升原理与用法实例浅析
2020/05/22 Javascript
python 布尔操作实现代码
2013/03/23 Python
Python解析json文件相关知识学习
2016/03/01 Python
Python 包含汉字的文件读写之每行末尾加上特定字符
2016/12/12 Python
NetworkX之Prim算法(实例讲解)
2017/12/22 Python
python2 与 python3 实现共存的方法
2018/07/12 Python
python中的字符串内部换行方法
2018/07/19 Python
python爬虫爬取微博评论案例详解
2019/03/27 Python
django富文本编辑器的实现示例
2019/04/10 Python
Python数据类型之List列表实例详解
2019/05/08 Python
Python3 A*寻路算法实现方式
2019/12/24 Python
python中scrapy处理项目数据的实例分析
2020/11/22 Python
python中复数的共轭复数知识点总结
2020/12/06 Python
UGG英国官方网站:UGG UK
2018/02/08 全球购物
欧洲领先的技术商店:eibmarkt.com
2019/05/10 全球购物
美国专业消费电子及摄影器材网站:B&H Photo Video
2019/12/18 全球购物
.NET程序员的数据库面试题
2012/10/10 面试题
亮化工程实施方案
2014/03/17 职场文书
国际贸易专业自荐信
2014/06/10 职场文书
毕业生个人自荐书
2015/03/05 职场文书
2015年度招聘工作总结
2015/05/28 职场文书
Go 自定义package包设置与导入操作
2021/05/06 Golang
JavaWeb 入门:Hello Servlet
2021/07/16 Java/Android
带你了解Java中的ForkJoin
2022/04/28 Java/Android