首页 > 其他分享 >除了 filter 还有什么置灰网站的方式?

除了 filter 还有什么置灰网站的方式?

时间:2022-12-05 14:06:21浏览次数:77  
标签:mix 网站 元素 filter 除了 mode blend backdrop

大家都知道,当一些重大事件发生的时候,我们的网站,可能需要置灰,像是这样:

除了 filter 还有什么置灰网站的方式?_混合模式

当然,通常而言,全站置灰是非常简单的事情,大部分前端同学都知道,仅仅需要使用一行 CSS,就能实现全站置灰的方式。

像是这样,我们仅仅需要给 HTML 添加一个统一的滤镜即可:

html {
filter: grayscale(.95);
-webkit-filter: grayscale(.95);
}

又或者,使用 SVG 滤镜,也可以快速实现网站的置灰:

<div>
// ...
</div>

<svg xmlns="https://www.w3.org/2000/svg">
<filter id="grayscale">
<feColorMatrix type="matrix" values="0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0 0 0 1 0"/>
</filter>
</svg>
html {
filter: url(#grayscale);
}

大部分时候,这样都可以解决大部分问题。不过,也有一些例外。譬如,如果我们仅仅需要置灰网站的首屏,而当用户开始滚动页面的时候,非首屏部分不需要置灰,像是如下动图所示,该怎么办呢?

看看示意:

除了 filter 还有什么置灰网站的方式?_混合模式_02

这种只置灰首屏的诉求该如何实现呢?

使用 backdrop-filter 实现滤镜遮罩

这里,我们可以借助 ​​backdrop-filter​​ 实现一种遮罩滤镜效果。

​filter​​​ VS ​​backdrop-filter​

在 CSS 中,有两个和滤镜相关的属性 -- ​​filter​​​ 和 ​​backdrop-filter​​。

​backdrop-filter​​ 是更为新的规范推出的新属性,可以点击查看 Filter Effects Module Level 2。

  • ​filter​​:该属性将模糊或颜色偏移等图形效果应用于元素。
  • ​backdrop-filter​​: 该属性可以让你为一个元素后面区域添加图形效果(如模糊或颜色偏移)。 它适用于元素背后的所有元素,为了看到效果,必须使元素或其背景至少部分透明。

注意两者之间的差异,​​filter​​​ 是作用于元素本身,而 ​​backdrop-filter​​ 是作用于元素背后的区域所覆盖的所有元素。而它们所支持的滤镜种类是一模一样的。

​backdrop-filter​​ 最为常见的使用方式是用其实现毛玻璃效果。

看这样一段代码:

<div class="bg">
<div>Normal</div>
<div class="g-filter">filter</div>
<div class="g-backdrop-filter">backdrop-filter</div>
</div>
.bg {
background: url(image.png);

& > div {
width: 300px;
height: 200px;
background: rgba(255, 255, 255, .7);
}
.g-filter {
filter: blur(6px);
}
.g-backdrop-filter {
backdrop-filter: blur(6px);
}
}

除了 filter 还有什么置灰网站的方式?_混合模式_03

​CodePen Demo -- filter 与 backdrop-filter 对比​

​filter​​​ 和 ​​backdrop-filter​​ 使用上最明显的差异在于:

  • ​filter​​ 作用于当前元素,并且它的后代元素也会继承这个属性
  • ​backdrop-filter​​ 作用于元素背后的所有元素

仔细区分理解,一个是当前元素和它的后代元素,一个是元素背后的所有元素

理解了这个,就能够明白为什么有了 ​​filter​​​,还会有 ​​backdrop-filter​​。

使用 backdrop-filter 实现首屏置灰遮罩

这样,我们可以快速的借助 backdrop-filter 实现首屏的置灰遮罩效果:

html {
position: relative;
width: 100%;
height: 100%;
overflow: scroll;
}
html::before {
content: "";
position: absolute;
inset: 0;
backdrop-filter: grayscale(95%);
z-index: 10;
}

仅仅只是这样而已,我们就在整个页面上方叠加了一层滤镜蒙版,实现了只对首屏页面的置灰:

除了 filter 还有什么置灰网站的方式?_滤镜_04

借助 pointer-events: none 保证页面交互

当然,这里有个很严重的问题,我们的页面是存在大量交互效果的,如果叠加了一层遮罩效果在其上,那这层遮罩下方的所有交互事件都将失效,譬如 hover、click 等。

那该如何解决呢?这个也好办,我们可以通过给这层遮罩添加上 ​​pointer-events: none​​,让这层遮罩不阻挡事件的点击交互。

代码如下:

html::before {
content: "";
position: absolute;
inset: 0;
backdrop-filter: grayscale(95%);
z-index: 10;
+ pointer-events: none;
}

​CodePen Demo -- Gray Website by backdrop-filter​

当然,有同学又会开始质疑了,​​backdrop-filter​​ 虽好,但是你自己瞅瞅它的兼容性,很多旧版 firefox 不支持啊大哥。我们那么多火狐的用户咋办?

截至至 2022/12/01,Firefox 的最新版本为 109,但是在 Firefox 103 之前,都是不支持 ​​backdrop-filter​​ 的。

别急,除了 ​​filter​​​ 和 ​​backdrop-filter​​,我们还有方式能够实现网站的置灰。

借助混合模式实现网站置灰

除了 ​​filter​​​ 和 ​​backdrop-filter​​​ 外,CSS 中另外一个能对颜色进行一些干预及操作的属性就是 ​​mix-blend-mode​​​ 和 ​​background-blend-mode​​ 了,翻译过来就是混合模式。

如果你对混合模式还比较陌生,可以看看我的这​​几篇文章​​:

这里,​​backdrop-filter​​​ 的替代方案是使用 ​​mix-blend-mode​​。

看看代码:

html {
position: relative;
width: 100%;
height: 100%;
overflow: scroll;
background: #fff;
}
html::before {
content: "";
position: absolute;
inset: 0;
background: rgba(0, 0, 0, 1);
mix-blend-mode: color;
pointer-events: none;
z-index: 10;
}

我们还是叠加了一层额外的元素在整个页面的首屏,并且把它的背景色设置成了黑色 ​​background: rgba(0, 0, 0, 1)​​,正常而言,我们的网站应该是一片黑色的。

但是,神奇的地方在于,通过混合模式的叠加,也能够实现网站元素的置灰。我们来看看效果:

经过实测:

{
mix-blend-mode: hue; // 色相
mix-blend-mode: saturation; // 饱和度
mix-blend-mode: color; // 颜色
}

上述 3 个混合模式,叠加黑色背景,都是可以实现内容的置灰的。

值得注意的是,上述方法,我们需要给 HTML 设置一个白色的背景色,同时,不要忘记了给遮罩层添加一个 ​​pointer-events: none​​。

​CodePen Demo -- Gray Website By MixBlendMode​

总结一下

这里,再简单总结一下。

  1. 如果你需要全站置灰,使用 CSS 的 ​​filter: grayscale()​
  2. 对于一些低版本的浏览器,使用 SVG 滤镜通过 ​​filter​​ 引入
  3. 对于仅仅需要首屏置灰的,可以使用 ​​backdrop-filter: grayscale()​​​ 配合 ​​pointer-events: none​
  4. 对于需要更好兼容性的,使用混合模式的 ​​mix-blend-mode: hue​​​、​​mix-blend-mode: saturation​​​、​​mix-blend-mode: color​​ 也都是非常好的方式

有个小技巧,在 CSS 的世界中,但凡和颜色打交道的事情,你都应该想起 ​​filter​​​、​​backdrop-filter​​​ 和 ​​mix-blend-mode​​。

最后

好了,本文到此结束,希望本文对你有所帮助

标签:mix,网站,元素,filter,除了,mode,blend,backdrop
From: https://blog.51cto.com/u_15566643/5911992

相关文章

  • 大型网站架构不得不考虑的10个问题
    这里的大型网站架构只包括高互动性高交互性的数据型大型网站,基于大家众所周知的原因,我们就不谈新闻类和一些依靠HTML静态化就可以实现的架构了,我们以高负载高数据交换高数据......
  • js中filter过滤用法总结
    定义和用法filter()方法创建一个新的数组,新数组中的元素是通过检查指定数组中符合条件的所有元素。注意:filter()不会对空数组进行检测。注意:filter()不会改变原始数组......
  • Web网站压力及性能测试
    一、Webbench测试并发Webbench是Linux下的一个网站压力测试工具,能测试处在相同硬件上,不同服务的性能以及不同硬件上同一个服务的运行状况。webbench的标准测试可以向我们展......
  • 网站变成灰色,这是怎么实现的?
    当大家看到全站的内容都变成了灰色,包括按钮、图片等等。这时候我们可能会好奇这是怎么做到的呢?有人会以为所有的内容都统一换了一个CSS样式,图片也全换成灰色的了,按钮等样......
  • 大型网站的架构设计问题----大型高并发高负载网站的系统架构
    我在Cernet做过拨号接入平台的搭建,而后在Yahoo3721负载搜索引擎前端平台开发,又在猫扑处理过大型社区猫扑大杂烩的架构升级等工作,同时自己接触和开发过不少大中型网站的模......
  • 延庆门头沟游戏网站高防BGP物理机
    而我们想说的是:影响服务器价格高低的因素有硬件配置、机房环境、带宽大小等等。那些价格极低的供应商也大都是些私人商家、二道贩子,并又没独立运营的能力,他们手中的资源......
  • 延庆门头沟高防网站BGP物理机
    可以根据自己的实际情况选择合适的服务器,这样不仅能控制支出成本,还能很好的起到防御作用,不然被攻击,严重的导致服务器瘫痪,对企业的损失是巨大的。实网络世界是连通的,如果置......
  • 延庆门头沟游戏网站高防物理机租用
    都喜欢“货比三家”,说白了也就是“价比三家”。面对价格差异巨大的海外服务器市场,我们的内心都是会趋向于价格低的哪些商家,但是,分钱分货的道理大家都知道,特别是一些网......
  • 延庆门头沟网站BGP物理机租用
    硬件防火墙是镶嵌系统内的,硬件防火墙是有软件和硬件结合而生成的,硬件防火墙从性能方面和防御方面都要比软件防火墙要好。最后还要提到的就是流量牵引技术,这是一种新型的防......
  • 十一、过滤器Filter(重点)
    Filter:过滤器,用来过滤网站的数据处理中文乱码登录验证....也就是说,web传进来的数据要经过这个接口Filter,把一些不想要的东西帮你过滤掉。1、在pom.xml中配置依赖......