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 display知识详解
Nov 25 HTML / CSS
HTML+CSS3模拟心的跳动实例代码
Sep 05 HTML / CSS
CSS3动画特效在活动页中的应用
Jan 21 HTML / CSS
HTML5地理定位与第三方工具百度地图的应用
Nov 17 HTML / CSS
检测浏览器是否支持html5视频的代码
Mar 28 HTML / CSS
谈一谈HTML5本地存储技术
Mar 02 HTML / CSS
html5使用canvas实现弹幕功能示例
Sep 11 HTML / CSS
基于HTML5 WebGL的3D机房的示例
Mar 16 HTML / CSS
canvas绘制树形结构可视图形的实现
Apr 03 HTML / CSS
HTML5基于flash实现播放RTMP协议视频的示例代码
Dec 04 HTML / CSS
HTML5适合的情人节礼物有纪念日期功能
Jan 25 HTML / CSS
CSS3 制作的书本翻页特效
Apr 13 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控制网页过期时间的代码
2008/09/28 PHP
php结合正则获取字符串中数字
2015/06/19 PHP
PHP错误和异常处理功能模块示例
2016/11/12 PHP
Mac系统下安装PHP Xdebug
2018/03/30 PHP
PHP折半(二分)查找算法实例分析
2018/05/12 PHP
用javascript实现在小方框中浏览大图的代码
2007/08/14 Javascript
网页上的Javascript编辑器和代码格式化
2010/04/25 Javascript
前端开发的开始---基于面向对象的Ajax类
2010/09/17 Javascript
javascript 另一种图片滚动切换效果思路
2012/04/20 Javascript
javascript实现日历控件(年月日关闭按钮)
2012/12/12 Javascript
打造个性化的功能强大的Jquery虚拟键盘(VirtualKeyboard)
2014/10/11 Javascript
javascript简单链式调用案例分析
2017/05/10 Javascript
详解angularJs中关于ng-class的三种使用方式说明
2017/06/02 Javascript
详解React-Native全球化多语言切换工具库react-native-i18n
2017/11/03 Javascript
vue.js根据代码运行环境选择baseurl的方法
2018/02/28 Javascript
vue.js 底部导航栏 一级路由显示 子路由不显示的解决方法
2018/03/09 Javascript
微信小程序实现聊天对话(文本、图片)功能
2018/07/06 Javascript
Angular resolve基础用法详解
2018/10/03 Javascript
AngularJS 多指令Scope问题的解决
2018/10/25 Javascript
vue+iview动态渲染表格详解
2019/03/19 Javascript
详解使用uni-app开发微信小程序之登录模块
2019/05/09 Javascript
学习LayUI时自研的表单参数校验框架案例分析
2019/07/29 Javascript
js实现图片上传到服务器和回显
2020/01/19 Javascript
koa2的中间件功能及应用示例
2020/03/05 Javascript
详解vue中v-on事件监听指令的基本用法
2020/07/22 Javascript
JS实现可以用键盘方向键控制的动画
2020/12/11 Javascript
python实现代码行数统计示例分享
2014/02/10 Python
python实现的生成随机迷宫算法核心代码分享(含游戏完整代码)
2014/07/11 Python
Python实现excel转sqlite的方法
2017/07/17 Python
利用Python实现原创工具的Logo与Help
2018/12/03 Python
python实现大战外星人小游戏实例代码
2019/12/26 Python
Python中if有多个条件处理方法
2020/02/26 Python
ASICS印度官方网站:日本专业运动品牌
2020/06/20 全球购物
2014年银行个人工作总结
2014/12/05 职场文书
村级干部党员公开承诺事项
2015/05/04 职场文书
Redis主从配置和底层实现原理解析(实战记录)
2021/06/30 Redis