整合營銷服務商

          電腦端+手機端+微信端=數據同步管理

          免費咨詢熱線:

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

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

          看看示意:

          這種只置灰首屏的訴求該如何實現呢?

          使用 backdrop-filter 實現濾鏡遮罩

          這里,我們可以借助 backdrop-filter 實現一種遮罩濾鏡效果。

          filterVSbackdrop-filter

          在 CSS 中,有兩個和濾鏡相關的屬性 -- filterbackdrop-filter

          backdrop-filter[1] 是更為新的規范推出的新屬性,可以點擊查看 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);
              }
          }
          

          CodePen Demo -- filter 與 backdrop-filter 對比[2]

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

          僅僅只是這樣而已,我們就在整個頁面上方疊加了一層濾鏡蒙版,實現了只對首屏頁面的置灰:


          借助 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[3]

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

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

          別急,除了 filterbackdrop-filter,我們還有方式能夠實現網站的置灰。

          借助混合模式實現網站置灰

          除了 filterbackdrop-filter 外,CSS 中另外一個能對顏色進行一些干預及操作的屬性就是 mix-blend-modebackground-blend-mode 了,翻譯過來就是混合模式。

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

          • 不可思議的顏色混合模式 mix-blend-mode[5]
          • 不可思議的混合模式 background-blend-mode[6]
          • CSS 奇技淫巧 | 妙用混合模式實現文字鏤空波浪效果[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;
          }
          

          我們還是疊加了一層額外的元素在整個頁面的首屏,并且把它的背景色設置成了黑色 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]

          總結一下

          這里,再簡單總結一下。

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

          有個小技巧,在 CSS 的世界中,但凡和顏色打交道的事情,你都應該想起 filterbackdrop-filtermix-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

          月 4 日舉行全國性哀悼活動,哀悼抗疫犧牲烈士和逝世同胞


          為表達全國各族人民對抗擊新冠肺炎疫情斗爭犧牲烈士和逝世同胞的深切哀悼,國務院發布公告,決定2020年4月4日舉行全國性哀悼活動。


          在此期間,全國和駐外使領館下半旗志哀,全國停止公共娛樂活動。4月4日10時起,全國人民默哀3分鐘,汽車、火車、艦船鳴笛,防空警報鳴響。


          我們能看到很多網站和app的首頁都換了灰色的。

          部分app開屏廣告也換成了哀悼相關的圖片

          常見的 比如 百度/必應/知乎/B站/網易云音樂/....




          我關注的好幾個博客 也換為了灰色


          10點的時候 聽到外面汽車的鳴笛聲,眼淚奪眶而出


          于是我也把我的個人網站改了一下樣式


          方法一,

          html{-webkit-filter: grayscale(100%);filter:progid:DXImageTransform.Microsoft.BasicImage(graysale=1);}


          <!-- 可以是整個網站變成灰色的 -->


          方法二,

          html { filter:progidXImageTransform.Microsoft.BasicImage(grayscale=1); }   使用方法:這段代碼可以變網頁為黑白,將代碼加到CSS最頂端就可以實現素裝。  如果網站沒有使用CSS,可以在網頁/模板的HTML代碼<head>和</head> 之間插入:<style>html{filter:progidXImageTransform.Microsoft.BasicImage(grayscale=1);}</style>


          另外頭像調整灰色的方法如下


          PS--圖像--調整--黑白



          手機端的方法是:打開圖片編輯--濾鏡--黑白



          有些人,永遠留在了這個冬天。


          愿逝者安息,英雄永垂不朽!

          通常我們在寫input時,它的背景文字框都是灰色的,樣式很單一,其實它可以做的更好看的,在CSS3中就專門提供了一屬性placeholder來實現輸入框的美化。接下來,就為大家展示下:

          HTML:

          CSS:

          效果:


          對于input輸入框的背景提示信息(placeholder)的美化雖然只是對網站應用的小小點綴,但正是這樣細節上的小差別將你的網站和別人的網站區別開來。IE10也支持了placeholder屬性哦!

          切版 qieban(.cn)


          主站蜘蛛池模板: 精品国产免费一区二区| 中文字幕一区视频一线| 亚洲AV无码一区东京热久久| 91在线一区二区| 精品天海翼一区二区| 久热国产精品视频一区二区三区| 国精品无码一区二区三区在线蜜臀| 国产一区二区三区免费在线观看| 麻豆国产一区二区在线观看| 久久se精品动漫一区二区三区| 亚洲国产精品一区二区第四页| 日本夜爽爽一区二区三区| 国精产品一区一区三区MBA下载 | 国产一区二区在线| 人妻AV中文字幕一区二区三区 | 成人一区专区在线观看| 无码播放一区二区三区| 亚洲制服中文字幕第一区| 亚洲国产精品一区第二页| 国产一区二区在线视频| 波多野结衣免费一区视频| 日本亚洲国产一区二区三区| 免费无码一区二区三区蜜桃| 综合久久一区二区三区 | 国产一区二区在线看| 日韩电影一区二区| 乱色精品无码一区二区国产盗| 无码人妻精品一区二区三区夜夜嗨 | 国产裸体歌舞一区二区| 国产精品va无码一区二区| 日韩在线不卡免费视频一区| 亚洲视频一区在线| 国产视频一区二区在线观看| 福利片福利一区二区三区| 区三区激情福利综合中文字幕在线一区亚洲视频1| 精品久久综合一区二区| aⅴ一区二区三区无卡无码| 国产一区二区三区免费观看在线| 国内精品无码一区二区三区| 色偷偷av一区二区三区| 女人18毛片a级毛片一区二区|