利用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无js实现的Android Logo(有简单动画)
Jan 21 HTML / CSS
初探CSS3中的calc()功能
Jul 14 HTML / CSS
基于Jquery和Css3代码制作可以缩放的搜索框
Nov 19 HTML / CSS
css3实现圆锥渐变conic-gradient效果
Feb 12 HTML / CSS
CSS3 实现的缩略图悬停效果
Dec 09 HTML / CSS
canvas学习笔记之2d画布基础的实现
Feb 21 HTML / CSS
使用css创建三角形 使用CSS3创建3d四面体原理及代码(html5实践)
Jan 06 HTML / CSS
用HTML5制作一个简单的弹力球游戏
May 12 HTML / CSS
SVG实现多彩圆环倒计时效果的示例代码
Nov 21 HTML / CSS
HTML5 语义化标签(移动端必备)
Aug 23 HTML / CSS
使用CSS实现一个搜索引擎的原理解析
Sep 25 HTML / CSS
CSS中float高度塌陷问题的四种解决方案
Apr 18 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中常用字符串处理代码片段整理
2011/11/07 PHP
PHP递归调用的小技巧讲解
2013/02/19 PHP
PHP实现的比较完善的购物车类
2014/12/02 PHP
PHP简单选择排序算法实例
2015/01/26 PHP
PHP实现的json类实例
2015/07/28 PHP
Symfony2学习笔记之系统路由详解
2016/03/17 PHP
JS查看对象功能代码
2008/04/25 Javascript
简单的js分页脚本
2009/05/21 Javascript
jQuery技巧总结
2011/01/01 Javascript
jQuery中需要注意的细节问题小结
2011/12/06 Javascript
javascript之典型高阶函数应用介绍
2013/01/10 Javascript
JS分页控件 可用于无刷新分页
2013/07/23 Javascript
javascript常见操作汇总
2014/09/03 Javascript
js实现飞入星星特效代码
2014/10/17 Javascript
使用Raygun来自动追踪AngularJS中的异常
2015/06/23 Javascript
javascript实现数组内值索引随机化及创建随机数组的方法
2015/08/10 Javascript
jQuery解析json格式数据简单实例
2016/01/22 Javascript
AngularJS中$http的交互问题
2017/03/29 Javascript
vue axios请求超时的正确处理方法
2018/04/02 Javascript
js实现一个页面多个倒计时的3种方法
2019/02/25 Javascript
关于JavaScript 数组你应该知道的事情(推荐)
2019/04/10 Javascript
python实现读取并显示图片的两种方法
2017/01/13 Python
对python mayavi三维绘图的实现详解
2019/01/08 Python
Python实现队列的方法示例小结【数组,链表】
2020/02/22 Python
一个基于canvas的移动端图片编辑器的实现
2020/10/28 HTML / CSS
网购亚洲时装、美容产品和生活百货:YesStyle
2016/09/15 全球购物
任意存:BOXFUL
2018/05/21 全球购物
Ryderwear澳洲官网:澳大利亚高端健身训练装备品牌
2018/09/18 全球购物
什么是继承
2013/12/07 面试题
法律专业应届本科毕业生求职信
2013/10/25 职场文书
生产厂长岗位职责
2014/02/21 职场文书
商业门面租房协议书
2014/11/25 职场文书
道德模范事迹材料
2014/12/20 职场文书
导游词之山西关帝庙
2019/11/01 职场文书
MySql学习笔记之事务隔离级别详解
2021/05/12 MySQL
Python 数据可视化工具 Pyecharts 安装及应用
2022/04/20 Python