利用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的@media来编写响应式的页面
Nov 01 HTML / CSS
前端面试必备之CSS3的新特性
Sep 05 HTML / CSS
深入浅出CSS3 background-clip,background-origin和border-image教程
Jan 27 HTML / CSS
CSS3的transition和animation的用法实例介绍
Aug 20 HTML / CSS
css3中transition属性详解
Sep 02 HTML / CSS
使用Html5、CSS实现文字阴影效果
Jan 17 HTML / CSS
html5 css3网站菜单实现代码
Dec 23 HTML / CSS
清除canvas画布内容(点擦除+线擦除)
Aug 12 HTML / CSS
amaze ui 的使用详细教程
Aug 19 HTML / CSS
css3实现背景图片半透明内容不透明的方法示例
Apr 13 HTML / CSS
html form表单基础入门案例讲解
Jul 15 HTML / CSS
分享CSS盒子模型隐藏的几种方式
Feb 28 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+Tidy-完美的XHTML纠错+过滤
2007/04/10 PHP
PHP实现找出有序数组中绝对值最小的数算法分析
2017/08/07 PHP
PHP如何根据文件头检测文件类型实例代码
2018/10/14 PHP
Discuz不使用插件实现简单的打赏功能
2019/03/21 PHP
[JS源码]超长文章自动分页(客户端版)
2007/01/09 Javascript
XML+XSL 与 HTML 两种方案的结合
2007/04/22 Javascript
js去空格技巧分别去字符串前后、左右空格
2013/10/21 Javascript
JQuery的ready函数与JS的onload的区别详解
2013/11/21 Javascript
jquery1.10给新增元素绑定事件的方法
2014/03/06 Javascript
jQuery实现ctrl+enter(回车)提交表单
2015/10/19 Javascript
高效利用Angular中内置服务$http、$location等
2016/03/22 Javascript
Bootstrap每天必学之响应式导航、轮播图
2016/04/25 Javascript
jQuery Ajax 实例代码 ($.ajax、$.post、$.get)
2016/04/29 Javascript
JS制作类似选项卡切换的年历
2016/12/03 Javascript
jQuery实现动态文字搜索功能
2017/01/05 Javascript
JavaScript 函数的定义-调用、注意事项
2017/04/16 Javascript
详解使用Node.js 将txt文件转为Excel文件
2017/07/05 Javascript
vue组件学习教程
2017/09/09 Javascript
基于Vue实现可以拖拽的树形表格实例详解
2018/10/18 Javascript
详解Vue+ElementUI从零开始搭建自己的网站(一、环境搭建)
2019/04/30 Javascript
vue实现节点增删改功能
2019/09/26 Javascript
jQuery表单校验插件validator使用方法详解
2020/02/18 jQuery
Angular处理未可知异常错误的方法详解
2021/01/17 Javascript
python正则表达式匹配[]中间为任意字符的实例
2018/12/25 Python
django创建简单的页面响应实例教程
2019/09/06 Python
完美解决TensorFlow和Keras大数据量内存溢出的问题
2020/07/03 Python
Html5实现首页动态视频背景的示例代码
2019/09/25 HTML / CSS
英国殿堂级有机护肤品牌:Rodial
2017/04/17 全球购物
Linux如何为某个操作添加别名
2015/02/05 面试题
大学生先进事迹材料
2014/02/16 职场文书
21岁生日感言
2014/02/27 职场文书
学生保证书范文
2014/04/28 职场文书
画展邀请函
2015/01/31 职场文书
教师个人发展总结
2015/02/11 职场文书
新闻稿标题
2015/07/18 职场文书
OpenCV实现常见的四种图像几何变换
2022/04/01 Python