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 相关文章推荐
a标签的css样式四个状态
Mar 09 HTML / CSS
CSS3 3D位移translate效果实例介绍
May 03 HTML / CSS
CSS3 选择器 基本选择器介绍
Jan 21 HTML / CSS
CSS3实现各种图形的示例代码
Oct 19 HTML / CSS
详解css3中 text-fill-color属性
Jul 08 HTML / CSS
html5中svg canvas和图片之间相互转化思路代码
Jan 24 HTML / CSS
在HTML5 Canvas中放入图片和保存为图片的方法
May 03 HTML / CSS
HTML5图片预览实例分享
Jun 04 HTML / CSS
详解如何用HTML5 Canvas API控制图片的缩放变换
Mar 22 HTML / CSS
Html5监听手机摇一摇事件的实现
Nov 07 HTML / CSS
HTML页面滚动时部分内容位置固定不滚动的实现
Apr 14 HTML / CSS
CSS SandBox应用场景及常见问题
Jun 25 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
利用php来自动调用不同服务器上的flash
2006/10/09 PHP
ThinkPHP3.1.3版本新特性概述
2014/06/19 PHP
thinkphp3.2中实现phpexcel导出带生成图片示例
2017/02/14 PHP
关于使用runtimeStyle属性问题讨论文章
2007/03/08 Javascript
ExtJS 设置级联菜单的默认值
2010/06/13 Javascript
很棒的学习jQuery的12个网站推荐
2011/04/28 Javascript
jquery 面包屑导航 具体实现
2013/06/05 Javascript
js实现网页自动刷新可制作节日倒计时效果
2014/05/27 Javascript
响应式表格之固定表头的简单实现
2016/08/26 Javascript
JS中页面与页面之间超链接跳转中文乱码问题的解决办法
2016/12/15 Javascript
Angular JS 生成动态二维码的方法
2017/02/23 Javascript
详解关于element el-button使用$attrs的一个注意要点
2018/11/09 Javascript
JS写滑稽笑脸运动效果
2020/05/28 Javascript
解决vue页面渲染但dom没渲染的操作
2020/07/27 Javascript
Python切片用法实例教程
2014/09/08 Python
python判断给定的字符串是否是有效日期的方法
2015/05/13 Python
Python中easy_install 和 pip 的安装及使用
2017/06/05 Python
解决PyCharm控制台输出乱码的问题
2019/01/16 Python
Python设计模式之原型模式实例详解
2019/01/18 Python
浅谈python常用程序算法
2019/03/22 Python
解决tensorflow由于未初始化变量而导致的错误问题
2020/01/06 Python
Python如何把多个PDF文件合并代码实例
2020/02/13 Python
Python基于类路径字符串获取静态属性
2020/03/12 Python
Python接口开发实现步骤详解
2020/04/26 Python
Python实现转换图片背景颜色代码
2020/04/30 Python
Python打印不合法的文件名
2020/07/31 Python
python 模块导入问题汇总
2021/02/01 Python
详解HTML5常用的语义化标签
2019/09/27 HTML / CSS
美国东北部户外服装和设备零售商:Eastern Mountain Sports
2016/10/05 全球购物
日本最大美瞳直送网:Morecontact(中文)
2019/04/03 全球购物
神话般的珠宝:Ross-Simons
2020/07/13 全球购物
生日宴会答谢词
2014/01/09 职场文书
局火灾防控工作方案
2014/05/25 职场文书
2014年学生会生活部工作总结
2014/11/07 职场文书
小鞋子观后感
2015/06/05 职场文书
JavaScript实例 ODO List分析
2022/01/22 Javascript