CSS3 毛玻璃效果


Posted in HTML / CSS onAugust 14, 2019

毛玻璃效果做的好能使页面显得非常生动立体。直接上图

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);
}

<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 毛玻璃效果

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

HTML / CSS 相关文章推荐
移动端rem布局的两种实现方法
Jan 03 HTML / CSS
纯CSS3实现鼠标悬停提示气泡效果
Feb 28 HTML / CSS
CSS3 display知识详解
Nov 25 HTML / CSS
CSS3实现swap交换动画
Jan 19 HTML / CSS
CSS3 中filter(滤镜)属性使用详解
Apr 07 HTML / CSS
html5 Canvas画图教程(4)—未闭合的路径及渐变色的填充方法
Jan 09 HTML / CSS
Canvas与Image互相转换示例代码
Aug 09 HTML / CSS
在canvas上实现元素图片镜像翻转动画效果的方法
Mar 20 HTML / CSS
通过canvas转换颜色为RGBA格式及性能问题的解决
Nov 22 HTML / CSS
浅析HTML5 meta viewport参数
Oct 28 HTML / CSS
详解CSS中的特指度和层叠问题
Jul 15 HTML / CSS
css3带你实现3D转换效果
Feb 24 HTML / CSS
详解css position 5种不同的值的用法
Jul 30 #HTML / CSS
CSS Houdini实现动态波浪纹效果
Jul 30 #HTML / CSS
使用css实现android系统的loading加载动画
Jul 25 #HTML / CSS
使用CSS3实现input多选框自定义样式的方法示例
Jul 19 #HTML / CSS
详解css3中 text-fill-color属性
Jul 08 #HTML / CSS
解决margin 外边距合并问题
Jul 03 #HTML / CSS
css3实现蒙版弹幕功能
Jun 18 #HTML / CSS
You might like
CodeIgniter错误mysql_connect(): No such file or directory解决方法
2014/09/06 PHP
一个php生成16位随机数的代码(两种方法)
2014/09/16 PHP
Thinkphp无限级分类代码
2015/11/11 PHP
PHP strip_tags() 去字符串中的 HTML、XML 以及 PHP 标签的函数
2016/05/22 PHP
php微信公众号js-sdk开发应用
2016/11/28 PHP
yii 2.0中表单小部件的使用方法示例
2017/05/23 PHP
jQuery创建自己的插件(自定义插件)的方法
2010/06/10 Javascript
ExtJS下书写动态生成的xml(兼容火狐)
2013/04/02 Javascript
JS实现窗口加载时模拟鼠标移动的方法
2015/06/03 Javascript
jquery延迟对象解析
2016/10/26 Javascript
解决vue脚手架项目打包后路由视图不显示的问题
2018/09/20 Javascript
浅谈JavaScript_DOM学习篇_图片切换小案例
2019/03/19 Javascript
javascript定时器的简单应用示例【控制方块移动】
2019/06/17 Javascript
js实现文字头像的生成代码
2020/03/07 Javascript
Python中文件遍历的两种方法
2014/06/16 Python
python实现的文件夹清理程序分享
2014/11/22 Python
python实现微信接口(itchat)详细介绍
2017/10/23 Python
PyCharm 常用快捷键和设置方法
2017/12/20 Python
Python with语句上下文管理器两种实现方法分析
2018/02/09 Python
python实现图书馆研习室自动预约功能
2018/04/27 Python
python 从文件夹抽取图片另存的方法
2018/12/04 Python
在python tkinter中Canvas实现进度条显示的方法
2019/06/14 Python
python通过对字典的排序,对json字段进行排序的实例
2020/02/27 Python
基于python实现把json数据转换成Excel表格
2020/05/07 Python
Python自定义聚合函数merge与transform区别详解
2020/05/26 Python
keras 多任务多loss实例
2020/06/22 Python
Sublime Text3最新激活注册码分享适用2020最新版 亲测可用
2020/11/12 Python
Waterford加拿大官方网站:世界著名的水晶杯品牌
2016/11/01 全球购物
美国尼曼百货官网:Neiman Marcus
2019/09/05 全球购物
总经理秘书工作职责
2013/12/26 职场文书
班组安全员工作职责
2014/02/01 职场文书
校园安全广播稿
2014/02/08 职场文书
中学优秀班主任事迹材料
2014/05/01 职场文书
搭讪开场白台词大全
2015/05/28 职场文书
Golang 使用Map实现去重与set的功能操作
2021/04/29 Golang
python操作xlsx格式文件并读取
2021/06/02 Python