• 妙用 CSS 构建花式透视背景效果


    本文将介绍一种巧用 background 配合 backdrop- filter 来构建有趣的透视背景效果的方式。

    本技巧源自于一名群友的提问,如何构建如 ElementUI 文档的一种顶栏背景特效,看看效果:

    仔细看,在页面的的滚动过程中,顶栏的背景不是白色的,也不是毛玻璃效果,而是能够将背景颗粒化:

    准确而言,是一种基于颗粒化的毛玻璃效果,元素首先是被颗粒化,其次,元素的边缘也是在一定程度上被虚化了。那么,我们该如何实现这个效果呢?

    需求拆解

    上述效果看似神奇,其实原理也非常简单。主要就是颗粒化的背景 background加上backdrop-filter: blur() 即可。

    首先,我们需要实现颗粒背景。

    我们利用 background 实现这样一个背景:

    <div>div>
    
    div {
        background: radial-gradient(transparent, #000 20px);
        background-size: 40px 40px;
    }
    

    从透明到黑色的径向渐变效果如下:

    需要注意的是,图里的白色部分其实透明的,可以透出背后的背景。此时,如果背景后面有元素,效果就会是这样:

    好,我们将 background: radial-gradient(transparent, #000 20px) 中的黑色替换成白色,效果如下:

    这里为了展示原理,每个径向渐变的圆设置的比较大,我们把它调整回正常大小:

    div {
        background: radial-gradient(transparent, rgba(255, 255, 255, 1) 2px);
        background-size: 4px 4px;
    }
    

    这样,我们就成功的将背景颗粒化:

    当然,此时透出的背景看上去非常生硬,也不美观,所以,我们还需要 backdrop-filter: blur(),我们加上一个试试看:

    div {
        background: radial-gradient(transparent, rgba(255, 255, 255, 1) 2px);
        background-size: 4px 4px;
        backdrop-filter: blur(10px);
    }
    

    这样,我们就实现了一开始所展示的效果:

    这里需要注意的是,background-size 的大小控制,和不同的 backdrop-filter: blur(10px) 值,都会影响效果。

    完整的 DEMO,你可以戳这里:CodePen Demo -- Mask Filter

    当然,掌握了这个技巧之后,我们可以尝试替换掉 background: radial-gradient() 图形,及改变 background-size,尝试各种不同形状的透视背景。简单举几个例子:

    div {
        background: linear-gradient(45deg, transparent, #fff 4px);
        background-size: 6px 6px;
        backdrop-filter: saturate(50%) blur(4px);
    }
    

    这里使用了 linear-gradient() 替换了 radila-gradient()

    最后

    一个非常小的技巧,运用在恰当的地方可以很好的提升页面的质感,你学会了吗?

    本文到此结束,希望对你有帮助 😃

    更多精彩 CSS 技术文章汇总在我的 Github -- iCSS ,持续更新,欢迎点个 star 订阅收藏。

    如果还有什么疑问或者建议,可以多多交流,原创文章,文笔有限,才疏学浅,文中若有不正之处,万望告知。

    想 Get 到最有意思的 CSS 资讯,千万不要错过我的 iCSS 公众号 😄 :

    image

    如果觉得文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
    打赏支持
    +

    (^_^)打个赏喝个咖啡(^_^)

    微信支付
    支付宝支付
  • 相关阅读:
    C++标准模板(STL)- 类型支持 (属性查询,获取数组类型在指定维度的大小)
    如何拿取 macOS 系统中的图标文件
    【云原生之kubernetes】在kubernetes集群下的jobs与cronjobs管理
    安卓基础学习 Day 20|安卓高级控件---翻页视图
    LeTax记录\documentclass{},authoryear属性使用
    SPI通信
    Qt设置horizontal line 和vertical line的颜色
    locust 的分布式
    手游帧率不稳定的原因是什么?
    S32K148_CAN驱动(裸机开发)
  • 原文地址:https://www.cnblogs.com/coco1s/p/16549752.html