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 相关文章推荐
CSS3制作翻转效果_动力节点Java学院整理
Jul 11 HTML / CSS
支持IE8的纯css3开发的响应式设计动画菜单教程
Nov 05 HTML / CSS
CSS3实现王者匹配时的粒子动画效果
Apr 12 HTML / CSS
详解通过变换矩阵实现canvas的缩放功能
Jan 14 HTML / CSS
HTML5实现锚点时请使用id取代name
Sep 06 HTML / CSS
HTML5 audio标签使用js进行播放控制实例
Apr 24 HTML / CSS
简单介绍HTML5中audio标签的使用
Sep 24 HTML / CSS
详解通过HTML5 Canvas实现图片的平移及旋转变化的方法
Mar 22 HTML / CSS
HTML5实现可缩放时钟代码
Aug 28 HTML / CSS
html5 canvas的绘制文本自动换行的示例代码
Sep 17 HTML / CSS
canvas拼图功能实现代码示例
Nov 21 HTML / CSS
浅谈CSS不规则边框的生成方案
May 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
推荐几部必看的DC动画电影
2020/03/03 欧美动漫
日本十大科幻动漫 宇宙骑士垫底,第一已成经典
2020/03/04 日漫
php使用cookie显示用户上次访问网站日期的方法
2015/01/26 PHP
Laravel 5 框架入门(二)构建 Pages 的管理功能
2015/04/09 PHP
PHP、Java des加密解密实例
2015/04/27 PHP
学习php设计模式 php实现备忘录模式(Memento)
2015/12/09 PHP
js数字输入框(包括最大值最小值限制和四舍五入)
2009/11/24 Javascript
用jquery实现自定义风格的滑动条实现代码
2011/04/26 Javascript
如何将一个String和多个String值进行比较思路分析
2013/04/22 Javascript
javaScript函数中执行C#代码中的函数方法总结
2013/08/07 Javascript
JS对文本框值的判断示例
2014/03/10 Javascript
JavaScript解析json格式数据简单示例
2014/12/09 Javascript
jquery获取节点名称
2015/04/26 Javascript
js实现人才网站职位选择功能的方法
2015/08/14 Javascript
解决前端跨域问题方案汇总
2016/11/20 Javascript
浅析JavaScript动画模拟拖拽原理
2016/12/09 Javascript
js代码实现下拉菜单【推荐】
2016/12/15 Javascript
十分钟教你上手ES2020新特性
2020/02/12 Javascript
vue实现拖拽进度条
2021/03/01 Vue.js
[56:42]VP vs RNG 2019国际邀请赛小组赛 BO2 第二场 8.15
2019/08/17 DOTA
TensorFlow实现AutoEncoder自编码器
2018/03/09 Python
利用pyuic5将ui文件转换为py文件的方法
2019/06/19 Python
Win10系统下安装labelme及json文件批量转化方法
2019/07/30 Python
Python递归函数 二分查找算法实现解析
2019/08/12 Python
基于python实现雪花算法过程详解
2019/11/16 Python
python画蝴蝶曲线图的实例
2019/11/21 Python
pytorch实现建立自己的数据集(以mnist为例)
2020/01/18 Python
基于Python把网站域名解析成ip地址
2020/05/25 Python
Expedia挪威官网:酒店、机票和租车
2018/03/03 全球购物
车间调度岗位职责
2013/11/30 职场文书
优秀学生干部推荐材料
2014/02/03 职场文书
机械制造毕业生求职信
2014/03/03 职场文书
小组口号大全
2014/06/09 职场文书
摄影专业毕业生求职信
2014/08/05 职场文书
《陶罐和铁罐》教学反思
2016/03/03 职场文书
二年级作文之动物作文
2019/11/13 职场文书