罩層基礎版。
基礎課中有朋友想了解遮罩層,今天就用四步完成英雄聯盟官網上的遮罩層效果。開始之前用十天的基礎課程知識做好準備工作。
·第一步:html結構和基礎樣式。添加一個did盒子,里面一個標題,兩行文本。此時遮罩層在主結構的下方,給遮罩層寫上固定寬高,背景顏色用黑色,帶點透明度。看下效果。標題和兩行文本寫上字體大小和字體顏色,看下效果。
·第二步:美化樣式。遮罩層添加背景圖片,不重復顯示,位置微調,文本內內容居中,標題居中設置,兩行文本也居中設置。看下效果。給遮罩層加上那邊距,讓里面內容整體垂直居中。
·第三步:調整遮罩層位置。遮罩層絕對定位,同時外層盒子寫上相對定位代碼,開始設置位置,看下效果。
·第四步:讓遮罩層先隱藏,鼠標經過時再顯示即可。
到此遮罩層效果就完成了。反過來用,只需要調整隱藏的順序,再加一點位置移動和顏色改變,效果更好。
下次再講講遮罩層的靈活運用。
家都知道,當一些重大事件發生的時候,我們的網站,可能需要置灰,像是這樣:
當然,通常而言,全站置灰是非常簡單的事情,大部分前端同學都知道,僅僅需要使用一行 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);
}
大部分時候,這樣都可以解決大部分問題。不過,也有一些例外。譬如,如果我們僅僅需要置灰網站的首屏,而當用戶開始滾動頁面的時候,非首屏部分不需要置灰,像是如下動圖所示,該怎么辦呢?
看看示意:
這種只置灰首屏的訴求該如何實現呢?
這里,我們可以借助 backdrop-filter 實現一種遮罩濾鏡效果。
在 CSS 中,有兩個和濾鏡相關的屬性 -- filter 和 backdrop-filter。
backdrop-filter[1] 是更為新的規范推出的新屬性,可以點擊查看 Filter Effects Module Level 2。
注意兩者之間的差異,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);
}
}
CodePen Demo -- filter 與 backdrop-filter 對比[2]
filter 和 backdrop-filter 使用上最明顯的差異在于:
仔細區分理解,一個是當前元素和它的后代元素,一個是元素背后的所有元素。
理解了這個,就能夠明白為什么有了 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;
}
僅僅只是這樣而已,我們就在整個頁面上方疊加了一層濾鏡蒙版,實現了只對首屏頁面的置灰:
當然,這里有個很嚴重的問題,我們的頁面是存在大量交互效果的,如果疊加了一層遮罩效果在其上,那這層遮罩下方的所有交互事件都將失效,譬如 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[3]
當然,有同學又會開始質疑了,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 了,翻譯過來就是混合模式。
如果你對混合模式還比較陌生,可以看看我的這幾篇文章[4]:
這里,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[9]
這里,再簡單總結一下。
有個小技巧,在 CSS 的世界中,但凡和顏色打交道的事情,你都應該想起 filter、backdrop-filter 和 mix-blend-mode。
好了,本文到此結束,希望本文對你有所幫助 :)
如果還有什么疑問或者建議,可以多多交流,原創文章,文筆有限,才疏學淺,文中若有不正之處,萬望告知。
[1]
backdrop-filter: https://drafts.fxtf.org/filter-effects-2/#BackdropFilterProperty
[2]
CodePen Demo -- filter 與 backdrop-filter 對比: 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 奇技淫巧 | 妙用混合模式實現文字鏤空波浪效果: 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
作者:SbCo
來源:微信公眾號:iCSS前端趣聞
出處:https://mp.weixin.qq.com/s/pwXyZ-MAemaBhlPC6KM0hA
天刷到前端大佬用css做了這樣一個按鈕效果,看到原理,我嘗試用fairygui做了一下。
·它的層級是這樣的,動起來是這樣的。
·修改一下緩動函數,帶點回彈。
·改下遮罩圖,這好像跟想象中不太一樣。
·再做一個常用的掃光效果,它實際上是這樣的。
這兩個效果都用了同一個技術,就是圖形遮罩,一個是css寫的,一個是工具編輯器。用工具好處是不管什么效果,程序是不用管的,都是設計師的想法自己調整。而css是一個說不清楚是程序還是設計的工作。以前有網頁設計師,現在變卷了,都是前端完成了,以后前端也沒了,只剩全棧。
把需要設計的部分做成工具留給設計師,也是我做可視化追求的方向,專業的事情交給專業的人。你覺得哪種更好?
*請認真填寫需求信息,我們會在24小時內與您取得聯系。