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 相关文章推荐
常用的四种CSS透明属性介绍
Apr 12 HTML / CSS
CSS3属性background-size使用指南
Dec 09 HTML / CSS
CSS3中的@keyframes关键帧动画的选择器绑定
Jun 13 HTML / CSS
css和css3弹性盒模型实现元素宽度(高度)自适应
May 15 HTML / CSS
详解HTML5新增标签
Nov 27 HTML / CSS
canvas像素画板的实现代码
Nov 21 HTML / CSS
HTML5 Web存储方式的localStorage和sessionStorage进行数据本地存储案例应用
Dec 09 HTML / CSS
Html5无刷新修改browser Url的方法
Jan 15 HTML / CSS
canvas 如何绘制线段的实现方法
Jul 12 HTML / CSS
html5录音功能实战示例
Mar 25 HTML / CSS
HTML5实现移动端弹幕动画效果
Aug 01 HTML / CSS
html5移动端自适应布局的实现
Apr 15 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程序61条面向对象分析设计的经验小结
2008/11/12 PHP
php中常用字符串处理代码片段整理
2011/11/07 PHP
php实现表单提交上传文件功能
2018/05/28 PHP
Mootools 1.2教程(2) DOM选择器
2009/09/14 Javascript
js控制表单奇偶行样式的简单方法
2013/07/31 Javascript
含有CKEditor的表单如何提交
2014/01/09 Javascript
JS的框架Polymer中的dom-if和is属性使用说明
2015/07/29 Javascript
基于jquery实现ajax无刷新评论
2020/08/19 Javascript
JS实现两周内自动登录功能
2017/03/23 Javascript
JavaScript订单操作小程序完整版
2017/06/23 Javascript
javaScript强制保留两位小数的输入数校验和小数保留问题
2018/05/09 Javascript
安装Node.js并启动本地服务的操作教程
2018/05/12 Javascript
element-ui中select组件绑定值改变,触发change事件方法
2018/08/24 Javascript
angularJS实现不同视图同步刷新详解
2018/10/09 Javascript
100行代码实现一个vue分页组功能
2018/11/06 Javascript
vant picker+popup 自定义三级联动案例
2020/11/04 Javascript
在Python中操作字符串之rstrip()方法的使用
2015/05/19 Python
Python实现线程池代码分享
2015/06/21 Python
Scrapy-redis爬虫分布式爬取的分析和实现
2017/02/07 Python
python调用Matplotlib绘制分布点并且添加标签
2018/05/31 Python
Python中三元表达式的几种写法介绍
2019/03/04 Python
python3实现二叉树的遍历与递归算法解析(小结)
2019/07/03 Python
Django实现微信小程序的登录验证功能并维护登录态
2019/07/04 Python
Python 中pandas索引切片读取数据缺失数据处理问题
2019/10/09 Python
PyCharm使用之配置SSH Interpreter的方法步骤
2019/12/26 Python
MyFrenchPharma中文网:最大的法国药妆平台
2016/10/07 全球购物
流行文化收藏品:Sideshow(DC漫画,星球大战,漫威)
2019/03/17 全球购物
倩碧澳大利亚官网:Clinique澳大利亚
2019/07/22 全球购物
巴西24小时在线药房:Drogasil
2020/06/20 全球购物
领导接待方案
2014/03/13 职场文书
群众对十八届四中全会的期盼
2014/10/17 职场文书
环保建议书作文500字
2015/09/14 职场文书
2016北大自主招生自荐信模板
2016/01/28 职场文书
Python实现视频中添加音频工具详解
2021/12/06 Python
CSS中float高度塌陷问题的四种解决方案
2022/04/18 HTML / CSS
js作用域及作用域链工作引擎
2022/07/07 Javascript