利用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弹性伸缩布局之box布局
Jul 12 HTML / CSS
css3 border-radius属性详解
Jul 05 HTML / CSS
css3.0新属性效果在ie下的解决方案
May 10 HTML / CSS
CSS3中利用animation属性创建雪花飘落特效
May 14 HTML / CSS
基于Jquery和Css3代码制作可以缩放的搜索框
Nov 19 HTML / CSS
css3实现动画的三种方式
Aug 24 HTML / CSS
html5 分层屏幕适配的方法
Mar 16 HTML / CSS
HTML5移动端开发遇见的东西
Oct 11 HTML / CSS
Html5无刷新修改browser Url的方法
Jan 15 HTML / CSS
Html5 FileReader实现即时上传图片功能实例代码
Sep 01 HTML / CSS
使用placeholder属性设置input文本框的提示信息
Feb 19 HTML / CSS
html5简介及新增功能介绍
May 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+mysql不用递归实现的无限级分类实例(非递归)
2014/07/08 PHP
ThinkPHP模版中导入CSS和JS文件的方法
2014/11/29 PHP
php.ini中的request_order推荐设置
2015/05/10 PHP
深入php内核之php in array
2015/11/10 PHP
超酷的网页音乐播放器DewPlayer使用方法
2010/12/18 Javascript
jQuery ajax 路由和过滤器使用说明
2011/08/02 Javascript
javascript自定义startWith()和endWith()的两种方法
2013/11/11 Javascript
js实现鼠标悬停图片上时滚动文字说明的方法
2015/02/17 Javascript
解决node-webkit 不支持html5播放mp4视频的方法
2015/03/11 Javascript
JS提交form表单实例分析
2015/12/10 Javascript
javascript之Array 数组对象详解
2016/06/07 Javascript
使用BootStrapValidator完成前端输入验证
2016/09/28 Javascript
微信小程序页面间通信的5种方式
2017/03/31 Javascript
详谈js遍历集合(Array,Map,Set)
2017/04/06 Javascript
layui中layer前端组件实现图片显示功能的方法分析
2017/10/13 Javascript
详谈commonjs模块与es6模块的区别
2017/10/18 Javascript
用React-Native+Mobx做一个迷你水果商城APP(附源码)
2017/12/25 Javascript
pageGroup.js实现分页功能
2019/07/27 Javascript
详解JavaScript 的执行机制
2020/09/18 Javascript
[05:28]刀塔密之一:团结则存
2014/07/03 DOTA
python 字符串转列表 list 出现\ufeff的解决方法
2017/06/22 Python
Python如何发布程序的详细教程
2018/10/09 Python
解决pycharm安装后代码区不能编辑的问题
2018/10/28 Python
Python2与Python3的区别实例总结
2019/04/17 Python
Bose法国官网:购买耳机、扬声器、家庭影院、专业音响
2017/12/21 全球购物
中国跨境在线时尚零售商:Bellelily
2018/04/06 全球购物
Topshop法国官网:英国快速时尚品牌
2018/04/08 全球购物
编写类String的构造函数、析构函数和赋值函数
2012/05/29 面试题
介绍一下linux的文件系统
2012/03/20 面试题
教学器材管理制度
2014/01/26 职场文书
企业法人授权委托书
2014/04/03 职场文书
《鸟岛》教学反思
2014/04/26 职场文书
英语通知范文
2015/04/22 职场文书
认识实习感想
2015/08/10 职场文书
golang 实现菜单树的生成方式
2021/04/28 Golang
Vue全局事件总线你了解吗
2022/02/24 Vue.js