利用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实现炫酷的飞机起飞动画
Sep 17 HTML / CSS
详解CSS3 用border写 空心三角箭头 (两种写法)
Sep 29 HTML / CSS
深入浅出CSS3 background-clip,background-origin和border-image教程
Jan 27 HTML / CSS
使用CSS3编写类似iOS中的复选框及带开关的按钮
Apr 11 HTML / CSS
CSS3改变浏览器滚动条样式
Jan 04 HTML / CSS
值得收藏的HTML5资源(学习html5的朋友可以收藏下)
Jul 20 HTML / CSS
使用CSS实现弹性视频html5案例实践
Dec 26 HTML / CSS
实例教程 利用html5和css3打造一款创意404页面
Oct 20 HTML / CSS
如何用canvas实现在线签名的示例代码
Jul 10 HTML / CSS
html5 input输入实时检测以及延时优化
Jul 18 HTML / CSS
HTML5 客户端数据库简易使用:IndexedDB
Dec 19 HTML / CSS
amazeui页面校验功能的实现代码
Aug 24 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回溯法解决0-1背包问题实例分析
2015/03/23 PHP
PHP中的多种加密技术及代码示例解析
2016/10/20 PHP
PHP缩略图生成和图片水印制作
2017/01/07 PHP
PHP简单实现模拟登陆功能示例
2017/09/15 PHP
PHP 裁剪图片
2021/03/09 PHP
求得div 下 img的src地址的js代码
2007/02/28 Javascript
Ext.FormPanel 提交和 Ext.Ajax.request 异步提交函数的区别
2009/11/12 Javascript
HTML5+setCutomValidity()函数验证表单实例分享
2015/04/24 Javascript
JS实现动态表格的添加,修改,删除功能(推荐)
2016/06/15 Javascript
原生js实现ajax方法(超简单)
2016/09/20 Javascript
Bootstrap Img 图片样式(推荐)
2016/12/13 Javascript
vue .sync修饰符的使用详解
2018/06/15 Javascript
Vue中 v-if 和v-else-if页面加载出现闪现的问题及解决方法
2018/10/12 Javascript
layui2.0使用table+laypage实现真分页
2019/07/27 Javascript
微信提示 在浏览器打开 效果实现过程解析
2019/09/10 Javascript
Vue作用域插槽实现方法及作用详解
2020/07/08 Javascript
Python实现的多线程端口扫描工具分享
2015/01/21 Python
python遍历 truple list dictionary的几种方法总结
2016/09/11 Python
python多维数组切片方法
2018/04/13 Python
python多线程调用exit无法退出的解决方法
2019/02/18 Python
Python实现钉钉发送报警消息的方法
2019/02/20 Python
python微信撤回监测代码
2019/04/29 Python
如何使用pyinstaller打包32位的exe程序
2019/05/26 Python
django框架中ajax的使用及避开CSRF 验证的方式详解
2019/12/11 Python
在pytorch中实现只让指定变量向后传播梯度
2020/02/29 Python
利用python 下载bilibili视频
2020/11/13 Python
CSS3图片旋转特效(360/60/-360度)
2013/10/10 HTML / CSS
HTML5 video循环播放多个视频的方法步骤
2020/08/06 HTML / CSS
香港草莓网土耳其网站:Strawberrynet TR
2017/03/02 全球购物
港湾网络笔试题
2014/04/19 面试题
总经理办公室主任岗位职责
2013/11/12 职场文书
鼓舞士气的口号
2014/06/16 职场文书
个人维稳承诺书
2015/05/04 职场文书
总结一些Java常用的加密算法
2021/06/11 Java/Android
Linux下使用C语言代码搭建一个简单的HTTP服务器
2022/04/13 Servers
GoFrame框架数据校验之校验结果Error接口对象
2022/06/21 Golang