关于前端:妙用-CSS-构建花式透视背景效果

67次阅读

共计 1401 个字符,预计需要花费 4 分钟才能阅读完成。

本文将介绍一种巧用 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 订阅珍藏。

如果还有什么疑难或者倡议,能够多多交换,原创文章,文笔无限,满腹经纶,文中若有不正之处,万望告知。

正文完
 0