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教程之倾斜页面
Jan 27 HTML / CSS
css3实例教程 一款纯css3实现的环形导航菜单
Oct 20 HTML / CSS
CSS3实现各种图形的示例代码
Oct 19 HTML / CSS
总结30个CSS3选择器
Apr 13 HTML / CSS
基于ccs3的timeline时间线实现方法
Apr 30 HTML / CSS
css3实现动画的三种方式
Aug 24 HTML / CSS
HTML5中canvas中的beginPath()和closePath()的重要性
Aug 24 HTML / CSS
canvas绘制文本内容自动换行的实现代码
Jan 14 HTML / CSS
如何让IE9以下版本(ie6/7/8)认识html5元素
Apr 01 HTML / CSS
Html5之title吸顶功能
Jun 04 HTML / CSS
html5 冒号分隔符对齐的实现
Jul 31 HTML / CSS
css3手动实现pc端横向滚动
Jun 21 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
SESSION信息保存在哪个文件目录下以及能够用来保存什么类型的数据
2012/06/17 PHP
关于svn冲突的解决方法
2013/06/21 PHP
ThinkPHP 3.2 数据分页代码分享
2014/10/14 PHP
PHP使用NuSOAP调用Web服务的方法
2015/07/18 PHP
基于php实现七牛抓取远程图片
2015/12/01 PHP
PHP中abstract(抽象)、final(最终)和static(静态)原理与用法详解
2020/06/05 PHP
jquery中的 $(&quot;#jb51&quot;)与document.getElementById(&quot;jb51&quot;) 的区别
2011/07/26 Javascript
alert和confirm功能介绍
2014/05/21 Javascript
javascript中Date format(js日期格式化)方法小结
2015/12/17 Javascript
JavaScript装饰器函数(Decorator)实例详解
2017/03/30 Javascript
JavaScript Canvas绘制圆形时钟效果
2020/08/20 Javascript
Vue循环组件加validate多表单验证的实例
2018/09/18 Javascript
Vue+webpack项目配置便于维护的目录结构教程详解
2018/10/14 Javascript
JavaScript实现简单轮播图效果
2018/12/01 Javascript
vue h5移动端禁止缩放代码
2019/10/28 Javascript
详解为什么Vue中不要用index作为key(diff算法)
2020/04/04 Javascript
vue等两个接口都返回结果再执行下一步的实例
2020/09/08 Javascript
js制作提示框插件
2020/12/24 Javascript
Python实现计算最小编辑距离
2016/03/17 Python
Python简单实现查找一个字符串中最长不重复子串的方法
2018/03/26 Python
在python中利用opencv简单做图片比对的方法
2019/01/24 Python
pandas DataFrame索引行列的实现
2019/06/04 Python
Pycharm生成可执行文件.exe的实现方法
2020/06/02 Python
Pytorch 解决自定义子Module .cuda() tensor失败的问题
2020/06/23 Python
Myprotein台湾官方网站:全球领先的运动营养品牌
2018/12/10 全球购物
eBay加拿大站:eBay.ca
2019/06/20 全球购物
测量工程专业求职信
2014/02/24 职场文书
先进学校事迹材料
2014/12/30 职场文书
计生个人工作总结
2015/02/28 职场文书
新员工试用期自我评价
2015/03/10 职场文书
2015年学校体育工作总结
2015/04/22 职场文书
黄埔军校观后感
2015/06/10 职场文书
pytorch 运行一段时间后出现GPU OOM的问题
2021/06/02 Python
CSS使用伪类控制边框长度的方法
2022/01/18 HTML / CSS
Vue操作Storage本地化存储
2022/04/29 Vue.js
解决Springboot PostMapping无法获取数据的问题
2022/05/06 Java/Android