利用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中Transform动画属性用法详解
Jul 04 HTML / CSS
CSS教程:CSS3圆角属性
Apr 02 HTML / CSS
css3背景图片透明叠加属性cross-fade简介及用法实例
Jan 08 HTML / CSS
CSS3绘制圆角矩形的简单示例
Sep 28 HTML / CSS
使用CSS3的font-face字体嵌入样式的方法讲解
May 13 HTML / CSS
移动web模拟客户端实现多方框输入密码效果【附代码】
Mar 25 HTML / CSS
HTML5单页面手势滑屏切换原理分析
Jul 10 HTML / CSS
html5教你做炫酷的碎片式图片切换 (canvas)
Jul 28 HTML / CSS
HTML5新特性之语义化标签
Oct 31 HTML / CSS
浅析HTML5 Landmark
Sep 11 HTML / CSS
HTML5 canvas实现的静态循环滚动播放弹幕
Jan 05 HTML / CSS
h5页面背景图很长要有滚动条滑动效果的实现
Jan 27 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
模仿OSO的论坛(五)
2006/10/09 PHP
PHP 裁剪图片成固定大小代码方法
2009/09/09 PHP
PHP全概率运算函数(优化版) Webgame开发必备
2011/07/04 PHP
PHP连接SQLSERVER 注意事项(附dll文件下载)
2012/06/28 PHP
php中Array2xml类实现数组转化成XML实例
2014/12/08 PHP
PHP面向对象多态性实现方法简单示例
2017/09/27 PHP
jQuery dialog 异步调用ashx,webservice数据的代码
2010/08/03 Javascript
jQuery1.6 使用方法二
2011/11/23 Javascript
ExtJS4中的requires使用方法示例介绍
2013/12/03 Javascript
JS验证邮箱格式是否正确的代码
2013/12/05 Javascript
javascript中数组array及string的方法总结
2014/11/28 Javascript
js计算德州扑克牌面值的方法
2015/03/04 Javascript
全屏js头像上传插件源码高清版
2016/03/29 Javascript
Bootstrap轮播插件使用代码
2016/10/11 Javascript
理解 javascript 中的函数表达式与函数声明
2017/07/07 Javascript
简单谈谈关于Angular Cli打包的事
2017/09/05 Javascript
结合Vue控制字符和字节的显示个数的示例
2018/05/17 Javascript
vue.js配合$.post从后台获取数据简单demo分享
2018/08/11 Javascript
JavaScript实现表单注册、表单验证、运算符功能
2018/10/15 Javascript
JS中创建自定义类型的常用模式总结【工厂模式,构造函数模式,原型模式,动态原型模式等】
2019/01/19 Javascript
vue基础之使用get、post、jsonp实现交互功能示例
2019/03/12 Javascript
使用node.JS中的url模块解析URL信息
2020/02/06 Javascript
在Python中操作时间之tzset()方法的使用教程
2015/05/22 Python
Python有序字典简单实现方法示例
2017/09/28 Python
Python 忽略warning的输出方法
2018/10/18 Python
windows下Pycharm安装opencv的多种方法
2020/03/05 Python
python使用openpyxl操作excel的方法步骤
2020/05/28 Python
印尼在线精品店:Berrybenka.com
2016/10/22 全球购物
蛋白质世界:Protein World
2017/11/23 全球购物
Perfume’s Club法国站:购买香水和化妆品
2019/05/02 全球购物
水产养殖学应届生求职信
2013/09/29 职场文书
大学生求职简历的自我评价范文
2013/10/12 职场文书
汽车检测与维修应届毕业生求职信
2013/10/19 职场文书
迟到检讨书400字
2014/01/13 职场文书
护理学专业求职信
2014/06/29 职场文书
分享15个Webpack实用的插件!!!
2021/03/31 Javascript