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);}……去掉那些式样方面的代码,上面实现毛玻璃效果的核心代码如下:body {    …    background: url("iphone.jpg") fixed 0 center;    background-size: cover;}main {    …    background: hsla(0,0%,100%,.3);}当然这个效果离我们的期望还有点距离,因为单纯的30%的透明度会让文字变的难以阅读。对页面来说背景图只是起美化作用,文字才是最核心的。你可以增大透明度的百分比,但这样页面会显得很死板。为了让文字便于阅读,又保持页面的生动活泼,可以对上面的mian标签的背景做模糊处理。你可能尝试blur滤镜,但可惜的是效果不对:main {    …    -webkit-filter: blur(3px);    filter: blur(3px);}用blur滤镜会将文字也模糊掉,更看不清了,只能放弃。正确的做法是给mian标签增加伪元素::before,在伪元素上使用blur滤镜:(为了效果演示,加上了红色背景色)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:main {    …    overflow: hidden;}main::before {    …    margin: -30px;}最后将伪元素的红色背景色替换成body的背景图即可,效果如下。你也可以点击这里,右键查看完整的源代码。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 毛玻璃效果做的好能使页面显得非常生动立体。直接上图 去掉那些式样方面的代码,上面实现毛玻璃效果的核心代码如下: 当...
    张歆琳阅读 12,236评论 4 43
  • 1、垂直对齐 如果你用CSS,则你会有困惑:我该怎么垂直对齐容器中的元素?现在,利用CSS3的Transform,...
    kiddings阅读 3,223评论 0 11
  • 1、属性选择器:id选择器 # 通过id 来选择类名选择器 . 通过类名来选择属性选择器 ...
    Yuann阅读 1,677评论 0 7
  • 一、在什么场景下会出现外边距合并?如何合并?如何不让相邻元素外边距合并?给个父子外边距合并的范例 在CSS当中,相...
    dengpan阅读 618评论 0 0
  • 夏至金乌复回首, 丝绦梅雨何时休。 月夜把盏伤四序, 仰看七曜梦九州。
    LinkinPark_9100阅读 217评论 0 0