利用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 相关文章推荐
HTML5时代CSS设置漂亮字体取代图片
Sep 04 HTML / CSS
浅谈css3中的渐进增强和优雅降级
Dec 01 HTML / CSS
详解CSS3中的box-sizing(content-box与border-box)
Apr 19 HTML / CSS
HTML5 canvas基本绘图之绘制线段
Jun 27 HTML / CSS
关于HTML5的22个初级技巧(图文教程)
Jun 21 HTML / CSS
为你的html5网页添加音效示例
Apr 03 HTML / CSS
使用 HTML5 Canvas 制作水波纹效果点击图片就会触发
Sep 15 HTML / CSS
Html5 Canvas动画基础碰撞检测的实现
Dec 06 HTML / CSS
元素水平垂直居中的方式
Mar 31 HTML / CSS
CSS预处理框架——Stylus
Apr 21 HTML / CSS
CSS极坐标的实例代码
Jun 03 HTML / CSS
css清除浮动clearfix:after的用法详解(附完整代码)
May 21 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+MySQL搭建聊天室功能实例代码
2012/08/20 PHP
php中smarty区域循环的方法
2015/06/11 PHP
php实现异步将远程链接上内容(图片或内容)写到本地的方法
2016/11/30 PHP
Thinkphp框架 表单自动验证登录注册 ajax自动验证登录注册
2016/12/27 PHP
php + nginx项目中的权限详解
2017/05/23 PHP
PHP依赖注入(DI)和控制反转(IoC)详解
2017/06/12 PHP
thinkphp5.1框架模板赋值与变量输出示例
2020/05/25 PHP
js导航栏单击事件背景变换示例代码
2014/01/13 Javascript
javascript中attribute和property的区别详解
2014/06/05 Javascript
javascript实现youku的视频代码自适应宽度
2015/05/25 Javascript
JavaScript数据结构学习之数组、栈与队列
2017/05/02 Javascript
vue router自动判断左右翻页转场动画效果
2017/10/10 Javascript
JS获取一个表单字段中多条数据并转化为json格式
2017/10/17 Javascript
微信小程序倒计时功能实现代码
2017/11/09 Javascript
Vue-CLI3.x 设置反向代理的方法
2018/12/06 Javascript
Vue基础学习之项目整合及优化
2019/06/02 Javascript
Python使用Supervisor来管理进程的方法
2015/05/28 Python
浅析Python 3 字符串中的 STR 和 Bytes 有什么区别
2018/10/14 Python
简单了解为什么python函数后有多个括号
2019/12/19 Python
浅谈PyTorch的可重复性问题(如何使实验结果可复现)
2020/02/20 Python
Python unittest基本使用方法代码实例
2020/06/29 Python
浅谈OpenCV中的新函数connectedComponentsWithStats用法
2020/07/05 Python
Django解决frame拒绝问题的方法
2020/12/18 Python
Python实现京东抢秒杀功能
2021/01/25 Python
matplotlib部件之矩形选区(RectangleSelector)的实现
2021/02/01 Python
Python LMDB库的使用示例
2021/02/14 Python
奥地利汽车配件店:Pkwteile.at
2017/03/10 全球购物
在C#中如何实现多态
2014/07/02 面试题
班级体育活动总结
2014/07/05 职场文书
目标责任书格式
2014/07/28 职场文书
终止劳动合同协议书
2014/10/05 职场文书
医药公司开票员岗位职责
2015/04/15 职场文书
学校运动会简讯
2015/07/20 职场文书
安全生产奖惩制度
2015/08/06 职场文书
漫画「狩龙人拉格纳」公开TV动画预告图
2022/03/22 日漫
Docker与K8s关系介绍不会Docker也可以使用K8s
2022/06/25 Servers