自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

除了Filter 還有什么置灰網(wǎng)站的方式?

開發(fā) 前端
通常而言,全站置灰是非常簡(jiǎn)單的事情,大部分前端同學(xué)都知道,僅僅需要使用一行 CSS,就能實(shí)現(xiàn)全站置灰的方式。

大家都知道,當(dāng)一些重大事件發(fā)生的時(shí)候,我們的網(wǎng)站,可能需要置灰,像是這樣:

圖片

當(dāng)然,通常而言,全站置灰是非常簡(jiǎn)單的事情,大部分前端同學(xué)都知道,僅僅需要使用一行 CSS,就能實(shí)現(xiàn)全站置灰的方式。

像是這樣,我們僅僅需要給 HTML 添加一個(gè)統(tǒng)一的濾鏡即可:

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

又或者,使用 SVG 濾鏡,也可以快速實(shí)現(xiàn)網(wǎng)站的置灰:

<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);
}

大部分時(shí)候,這樣都可以解決大部分問(wèn)題。不過(guò),也有一些例外。譬如,如果我們僅僅需要置灰網(wǎng)站的首屏,而當(dāng)用戶開始滾動(dòng)頁(yè)面的時(shí)候,非首屏部分不需要置灰,像是如下動(dòng)圖所示,該怎么辦呢?

看看示意:

圖片

這種只置灰首屏的訴求該如何實(shí)現(xiàn)呢?

使用 backdrop-filter 實(shí)現(xiàn)濾鏡遮罩

這里,我們可以借助 backdrop-filter 實(shí)現(xiàn)一種遮罩濾鏡效果。

filter? VS backdrop-filter

在 CSS 中,有兩個(gè)和濾鏡相關(guān)的屬性 --  filter? 和 backdrop-filter。

backdrop-filter[1] 是更為新的規(guī)范推出的新屬性,可以點(diǎn)擊查看 Filter Effects Module Level 2。

  • filter:該屬性將模糊或顏色偏移等圖形效果應(yīng)用于元素。
  • backdrop-filter:該屬性可以讓你為一個(gè)元素后面區(qū)域添加圖形效果(如模糊或顏色偏移)。它適用于元素背后的所有元素,為了看到效果,必須使元素或其背景至少部分透明。

注意兩者之間的差異,filter? 是作用于元素本身,而 backdrop-filter 是作用于元素背后的區(qū)域所覆蓋的所有元素。而它們所支持的濾鏡種類是一模一樣的。

backdrop-filter 最為常見(jiàn)的使用方式是用其實(shí)現(xiàn)毛玻璃效果。

看這樣一段代碼:

<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);
}
}

圖片

?CodePen Demo -- filter 與 backdrop-filter 對(duì)比[2]。

filter? 和 backdrop-filter 使用上最明顯的差異在于:

  • filter 作用于當(dāng)前元素,并且它的后代元素也會(huì)繼承這個(gè)屬性。
  • backdrop-filter 作用于元素背后的所有元素。

仔細(xì)區(qū)分理解,一個(gè)是當(dāng)前元素和它的后代元素,一個(gè)是元素背后的所有元素。

理解了這個(gè),就能夠明白為什么有了 filter?,還會(huì)有 backdrop-filter。

使用 backdrop-filter 實(shí)現(xiàn)首屏置灰遮罩

這樣,我們可以快速的借助 backdrop-filter 實(shí)現(xiàn)首屏的置灰遮罩效果:

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

僅僅只是這樣而已,我們就在整個(gè)頁(yè)面上方疊加了一層濾鏡蒙版,實(shí)現(xiàn)了只對(duì)首屏頁(yè)面的置灰:

圖片

借助 pointer-events: none 保證頁(yè)面交互

當(dāng)然,這里有個(gè)很嚴(yán)重的問(wèn)題,我們的頁(yè)面是存在大量交互效果的,如果疊加了一層遮罩效果在其上,那這層遮罩下方的所有交互時(shí)間都將失效,譬如 hover、click 等。

那該如何解決呢?這個(gè)也好辦,我們可以通過(guò)給這層遮罩添加上 pointer-events: none,讓這層遮罩不阻擋事件的點(diǎn)擊交互。

代碼如下:

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

?CodePen Demo -- Gray Website  by backdrop-filter[3]。

當(dāng)然,有同學(xué)又會(huì)開始質(zhì)疑了,backdrop-filter 雖好,但是你自己瞅瞅它的兼容性,很多舊版 firefox 不支持啊大哥。我們那么多火狐的用戶咋辦?

截至至 2022/12/01,F(xiàn)irefox 的最新版本為 109,但是在 Firefox 103 之前,都是不支持 backdrop-filter 的。

別急,除了 filter? 和 backdrop-filter,我們還有方式能夠?qū)崿F(xiàn)網(wǎng)站的置灰。

借助混合模式實(shí)現(xiàn)網(wǎng)站置灰

除了 filter? 和 backdrop-filter? 外,CSS 中另外一個(gè)能對(duì)顏色進(jìn)行一些干預(yù)及操作的屬性就是 mix-blend-mode? 和 background-blend-mode 了,翻譯過(guò)來(lái)就是混合模式。

如果你對(duì)混合模式還比較陌生,可以看看我的這幾篇文章[4]:

  • 不可思議的顏色混合模式 mix-blend-mode[5]。
  • 不可思議的混合模式 background-blend-mode[6]。
  • CSS 奇技淫巧 | 妙用混合模式實(shí)現(xiàn)文字鏤空波浪效果[7]?。
  • 利用混合模式,讓文字智能適配背景顏色[8]?。

這里,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;
}

我們還是疊加了一層額外的元素在整個(gè)頁(yè)面的首屏,并且把它的背景色設(shè)置成了黑色 background: rgba(0, 0, 0, 1),正常而言,我們的網(wǎng)站應(yīng)該是一片黑色的。

但是,神奇的地方在于,通過(guò)混個(gè)模式的疊加,也能夠?qū)崿F(xiàn)網(wǎng)站元素的置灰。我們來(lái)看看效果:

圖片

經(jīng)過(guò)實(shí)測(cè):

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

上述 3 個(gè)混合模式,疊加黑色背景,都是可以實(shí)現(xiàn)內(nèi)容的置灰的。

值得注意的是,上述方法,我們需要給 HTML 設(shè)置一個(gè)白色的背景色,同時(shí),不要忘記了給遮罩層添加一個(gè) pointer-events: none。

CodePen Demo -- Gray Website  By MixBlendMode[9]?

總結(jié)一下

這里,再簡(jiǎn)單總結(jié)一下。

  1. 如果你需要全站置灰,使用 CSS 的filter: grayscale()。
  2. 對(duì)于一些低版本的瀏覽器,使用 SVG 濾鏡通過(guò)filter 引入。
  3. 對(duì)于僅僅需要首屏置灰的,可以使用backdrop-filter: grayscale() 配合 pointer-events: none。
  4. 對(duì)于需要更好兼容性的,使用混合模式的mix-blend-mode: hue、mix-blend-mode: saturation、mix-blend-mode: color 也都是非常好的方式。

有個(gè)小技巧,在 CSS 的世界中,但凡和顏色打交道的事情,你都應(yīng)該想起 filter、backdrop-filter 和 mix-blend-mode。

最后

好了,本文到此結(jié)束,希望本文對(duì)你有所幫助 :)

參考資料

[1]backdrop-filter: https://drafts.fxtf.org/filter-effects-2/#BackdropFilterProperty?。

[2]CodePen Demo -- filter 與 backdrop-filter 對(duì)比: https://codepen.io/Chokcoco/pen/WNjebrr?。

[3]CodePen Demo -- Gray Website  by backdrop-filter: https://codepen.io/Chokcoco/pen/zYaJQJm?。

[4]幾篇文章: https://github.com/chokcoco/iCSS/issues?q=is%3Aopen+label%3A%E6%B7%B7%E5%90%88%E6%A8%A1%E5%BC%8F?。

[5]不可思議的顏色混合模式 mix-blend-mode: https://github.com/chokcoco/iCSS/issues/16?。

[6]不可思議的混合模式 background-blend-mode: https://github.com/chokcoco/iCSS/issues/31?。

[7]CSS 奇技淫巧 | 妙用混合模式實(shí)現(xiàn)文字鏤空波浪效果: https://github.com/chokcoco/iCSS/issues/140?。

[8]利用混合模式,讓文字智能適配背景顏色: https://github.com/chokcoco/iCSS/issues/169?。

[9]CodePen Demo -- Gray Website  By MixBlendMode: https://codepen.io/Chokcoco/pen/poKOmxp?。

[10]Github -- iCSS: https://github.com/chokcoco/iCSS?。

責(zé)任編輯:姜華 來(lái)源: iCSS前端趣聞
相關(guān)推薦

2015-10-28 10:31:47

2015-08-10 14:54:57

公有云云安全數(shù)據(jù)加密

2012-06-19 09:21:17

BYOD

2018-01-24 05:08:24

2018-10-09 13:23:22

2020-10-25 17:11:29

JDK代理監(jiān)控

2020-04-17 11:45:30

程序員技術(shù)創(chuàng)業(yè)

2024-07-31 11:26:05

反射BeanXML

2022-01-20 08:44:25

HashMap死循環(huán)開放性

2012-03-05 13:21:35

筆記本評(píng)測(cè)

2012-02-22 10:23:59

WAN優(yōu)化帶寬管理

2020-06-17 07:56:19

前端存儲(chǔ)數(shù)據(jù)

2016-10-26 08:57:13

HadoopScrapy大數(shù)據(jù)

2017-01-15 14:18:35

大數(shù)據(jù)HadoopScrapy

2021-08-30 08:40:02

網(wǎng)頁(yè)404HTTP

2020-07-29 22:46:59

容器KubernetesPaaS

2020-08-10 11:54:36

人工智能機(jī)器學(xué)習(xí)AI

2018-11-26 08:16:05

無(wú)線路由器WiFi網(wǎng)絡(luò)

2020-10-19 15:39:34

人工智能

2017-02-21 18:36:54

時(shí)間序列分析數(shù)據(jù)統(tǒng)計(jì)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)