整合營(yíng)銷服務(wù)商

          電腦端+手機(jī)端+微信端=數(shù)據(jù)同步管理

          免費(fèi)咨詢熱線:

          使用CSS隱藏頁(yè)面元素的幾種方法,你知道它們的具體區(qū)別嗎?


          一說(shuō)起隱藏HTML頁(yè)面上的元素,很多人第一反應(yīng)就是設(shè)置元素的css屬性display:none;值,這是一種最常見的隱藏頁(yè)面元素方法。本篇文章我們就一起看看使用CSS隱藏頁(yè)面元素的方法,以及它們的區(qū)別。

          本篇文章中的例子直接放到github地址中,感興趣的同學(xué)可以自取。

          https://github.com/zhouxiongking/article-pages/blob/master/articles/hideElement/hideElement.html

          CSS

          方法1-display:none

          正如上文說(shuō)的一樣,最簡(jiǎn)單也最粗暴的方法就是設(shè)置元素的display屬性為none;

          display:none;

          設(shè)置為display:none;的元素將不會(huì)再占用頁(yè)面空間,其占用的空間會(huì)被其他元素所占有,從而會(huì)引起瀏覽器的重排和重匯。

          方法2-visibility: hidden

          另外一種方法是設(shè)置元素的visibility屬性為hidden。

          visibility: hidden

          這種做法雖然能夠隱藏元素,但是該元素仍會(huì)占用頁(yè)面空間,因此只會(huì)導(dǎo)致瀏覽器的重匯而不會(huì)引起重排。

          如果希望元素隱藏后不會(huì)引起頁(yè)面布局的變化,則推薦使用visibility:hidden;方式。

          方法3-opacity:0

          設(shè)置元素透明度opacity屬性為0,也可以隱藏頁(yè)面元素。

          opacity:0

          在呈現(xiàn)上與visibility:hidden;方式一樣,同樣會(huì)占據(jù)頁(yè)面空間。

          差異性-頁(yè)面布局

          對(duì)頁(yè)面布局的影響主要是看是否會(huì)引起瀏覽器的重匯和重排,對(duì)應(yīng)的差異如下圖所示。

          頁(yè)面布局差異

          差異性-事件綁定

          • display:none;的元素會(huì)直接從頁(yè)面上消失,因此在該元素上綁定的事件不會(huì)生效。

          • visibility: hidden;的元素不會(huì)觸發(fā)綁定的事件。

          • opacity:0; 的元素會(huì)觸發(fā)綁定的事件,例如點(diǎn)擊會(huì)觸發(fā)click函數(shù)。

          我們可以通過(guò)以下的例子來(lái)看看。

          首先我們定義兩個(gè)div,分別設(shè)置為visibility: hidden;和opacity:0,在兩個(gè)div上分別綁定一個(gè)click事件。

          定義div元素

          綁定的事件

          當(dāng)我們?cè)趦蓚€(gè)元素都進(jìn)行點(diǎn)擊時(shí),可以在控制臺(tái)看到如下輸出結(jié)果。

          結(jié)果

          從上述結(jié)果可以看出和上述結(jié)論一致。

          差異性-動(dòng)畫屬性

          • display:none;的元素會(huì)直接從頁(yè)面消失,因此定義transition效果完全無(wú)效。

          • visibility:hidden;的元素會(huì)在transition設(shè)置的時(shí)間內(nèi)消失,但是沒(méi)有動(dòng)畫效果。

          • opacity:0;的元素可以和正常元素一樣,從頁(yè)面以動(dòng)畫效果消失。

          同樣我們可以通過(guò)以下這個(gè)例子來(lái)看看。

          首先,我們定義兩個(gè)div,并設(shè)置其transition屬性。

          div元素

          定義transition效果

          我們通過(guò)將鼠標(biāo)移至元素上,可以看到兩者的差異,從而驗(yàn)證了上述結(jié)論的正確性。

          結(jié)束語(yǔ)

          本篇文章主要講解了使用CSS隱藏元素的幾種常用方法,并講解了它們之間的區(qū)別,以便大家在特定的場(chǎng)景中進(jìn)行選擇。

          2021 年最后一天,疫情還沒(méi)有完全結(jié)束,武漢市政府也取消了跨年活動(dòng)。今晚,就連地鐵都提前到 9 點(diǎn)關(guān)閉,大家都在家里跨年。這不,我也在家里跨年。不過(guò)我并沒(méi)有看晚會(huì),而是整理了一篇前端小技巧,算是給自己 2021年一個(gè)小小的總結(jié)。


          正文

          用 CSS 隱藏元素有很多種方法,這里介紹 3 種常見的。

          opacity: 0

          特點(diǎn)是【看不見,占空間,摸得著

          • 元素隱藏
          • 不改變布局
          • 如果綁定了事件,點(diǎn)擊該區(qū)域,是可以觸發(fā)事件的

          visibility: hidden

          特點(diǎn)是【看不見,占空間,摸不著

          • 元素隱藏
          • 不改變布局
          • 如果綁定了事件,點(diǎn)擊該區(qū)域,是無(wú)法觸發(fā)事件的

          display: none

          特點(diǎn)是【看不見,不占空間,摸不著

          • 元素隱藏
          • 改變布局
          • 如果綁定了事件,點(diǎn)擊該區(qū)域,是無(wú)法觸發(fā)事件的

          接下來(lái),我們來(lái)編寫代碼驗(yàn)證一下。首先寫入三個(gè)方塊,對(duì)中間的橙色方塊添加點(diǎn)擊事件。代碼及頁(yè)面效果如下所示:

          <!DOCTYPE html>
          <html>
              <head>
                  <style type="text/css">
                      .box {width: 200px;height: 50px;}
                      .red {background-color: red;}
                      .orange {background-color: orange;}
                      .yellow {background-color: yellow;}
                  </style>
              </head>
          
              <body>
                  <div>
                      <div class='box red'></div>
                      <div class='box orange' id="btn"></div>
                      <div class='box yellow'></div>
                  </div>
                  <script type="text/javascript">
                      document.getElementById("btn").onclick = function() {
                          alert('觸發(fā)點(diǎn)擊操作 0.0');
                      }
                  </script>
              </body>
          </html>

          image

          image

          image

          opacity: 0

          對(duì)中間橙色方塊添加 opacity: 0 樣式,代碼及效果如下:

          • 元素隱藏
          • 不改變布局
          • 如果綁定了事件,點(diǎn)擊該區(qū)域,是可以觸發(fā)事件的
          <!DOCTYPE html>
          <html>
              <head>
                  <style type="text/css">
                      .box {width: 200px;height: 50px;}
                      .red {background-color: red;}
                      .orange {background-color: orange;}
                      .yellow {background-color: yellow;}
                      .opacity {opacity: 0}
                  </style>
              </head>
          
              <body>
                  <div>
                      <div class='box red'></div>
                      <div class='box orange opacity' id="btn"></div>
                      <div class='box yellow'></div>
                  </div>
                  <script type="text/javascript">
                      document.getElementById("btn").onclick = function() {
                          alert('觸發(fā)點(diǎn)擊操作 0.0');
                      }
                  </script>
              </body>
          </html>

          image

          image

          image

          visibility: hidden

          對(duì)中間橙色方塊添加 visibility: hidden 樣式,代碼及效果如下:

          • 元素隱藏
          • 不改變布局
          • 如果綁定了事件,點(diǎn)擊該區(qū)域,是無(wú)法觸發(fā)事件的
          <!DOCTYPE html>
          <html>
              <head>
                  <style type="text/css">
                      .box {width: 200px;height: 50px;}
                      .red {background-color: red;}
                      .orange {background-color: orange;}
                      .yellow {background-color: yellow;}
                      .visibility {visibility: hidden}
                  </style>
              </head>
          
              <body>
                  <div>
                      <div class='box red'></div>
                      <div class='box orange visibility' id="btn"></div>
                      <div class='box yellow'></div>
                  </div>
                  <script type="text/javascript">
                      document.getElementById("btn").onclick = function() {
                          alert('觸發(fā)點(diǎn)擊操作 0.0');
                      }
                  </script>
              </body>
          </html>

          image

          image

          image

          display: none

          對(duì)中間橙色方塊添加 display: none 樣式,代碼及效果如下:

          • 元素隱藏
          • 改變布局
          • 如果綁定了事件,點(diǎn)擊該區(qū)域,是無(wú)法觸發(fā)事件的
          <!DOCTYPE html>
          <html>
              <head>
                  <style type="text/css">
                      .box {width: 200px;height: 50px;}
                      .red {background-color: red;}
                      .orange {background-color: orange;}
                      .yellow {background-color: yellow;}
                      .display {display: none}
                  </style>
              </head>
          
              <body>
                  <div>
                      <div class='box red'></div>
                      <div class='box orange display' id="btn"></div>
                      <div class='box yellow'></div>
                  </div>
                  <script type="text/javascript">
                      document.getElementById("btn").onclick = function() {
                          alert('觸發(fā)點(diǎn)擊操作 0.0');
                      }
                  </script>
              </body>
          </html>

          image

          image


          結(jié)尾

          本人 2021 年度成就總結(jié):

          1. 學(xué)術(shù)方面,憑借個(gè)人努力,在核酸檢測(cè)領(lǐng)域產(chǎn)出多份數(shù)據(jù)真實(shí)詳盡的報(bào)告。
          2. 健康方面,保證膳食纖維攝入,具體表現(xiàn)為每日?qǐng)?jiān)持吃瓜,吃好瓜,吃大瓜。
          3. 商業(yè)方面,與各大平臺(tái)合作,全面參與投資 618、雙 11、雙 12 等千億級(jí)重大項(xiàng)目。
          4. 環(huán)保方面,股票基金一片綠,綠水青山就是金山銀山。在廢物利用領(lǐng)域更是成績(jī)斐然:自己作為廢物,常常被別人利用。
          5. 運(yùn)動(dòng)方面,專注于水上項(xiàng)目,在摸魚、劃水等小項(xiàng)上有突出表現(xiàn)。

          最后,祝大家元旦快樂(lè)~

          CSS 隱藏頁(yè)面元素有許多種方法。你可以將 opacity 設(shè)為 0、將 visibility 設(shè)為 hidden、將 display 設(shè)為 none 或者將 position 設(shè)為 absolute 然后將位置設(shè)到不可見區(qū)域。

          你有沒(méi)有想過(guò),為什么我們要有這么多技術(shù)來(lái)隱藏元素,而它們看起來(lái)都實(shí)現(xiàn)的是同樣的效果?每一種方法實(shí)際上與其他方法之間都有一些細(xì)微的不同,這些 不同決定了在一個(gè)特定的場(chǎng)合下使用哪一個(gè)方法。這篇教程將覆蓋到那些你需要記住的細(xì)小不同點(diǎn),讓你根據(jù)不同情況選擇上面這些方法中適合的方法來(lái)隱藏元素。

          opacity

          opacity 屬性的意思是設(shè)置一個(gè)元素的透明度。它不是為改變?cè)氐倪吔缈颍╞ounding box)而設(shè)計(jì)的。這意味著將 opacity 設(shè)為 0 只能從視覺(jué)上隱藏元素。而元素本身依然占據(jù)它自己的位置并對(duì)網(wǎng)頁(yè)的布局起作用。它也將響應(yīng)用戶交互。

          .hide {
           opacity: 0;}

          如果你打算使用 opacity 屬性在讀屏軟件中隱藏元素,很不幸,你并不能如愿。元素和它所有的內(nèi)容會(huì)被讀屏軟件閱讀,就像網(wǎng)頁(yè)上的其他元素那樣。換句話說(shuō),元素的行為就和它們不透明時(shí)一致。

          我還要提醒一句,opacity 屬性可以用來(lái)實(shí)現(xiàn)一些效果很棒的動(dòng)畫。任何 opacity 屬性值小于 1 的元素也會(huì)創(chuàng)建一個(gè)新的堆疊上下文(stacking context)。

          看下面的例子:

          看 @SitePoint 提供的例子“用 opacity 隱藏元素”

          當(dāng)你的鼠標(biāo)移到被隱藏的第 2 個(gè)的區(qū)塊上,元素狀態(tài)平滑地從完全透明過(guò)渡到完全不透明。區(qū)塊也將 cursor 屬性設(shè)置為了 pointer,這說(shuō)明了用戶可以與它交互。

          我自己是一名從事了多年開發(fā)的web前端老程序員,目前辭職在做自己的web前端私人定制課程,今年年初我花了一個(gè)月整理了一份最適合2019年學(xué)習(xí)的web前端學(xué)習(xí)干貨,各種框架都有整理,送給每一位前端小伙伴,想要獲取的可以關(guān)注我的頭條號(hào)并在后臺(tái)私信我:前端,即可免費(fèi)獲取。

          visibility

          第二個(gè)要說(shuō)的屬性是 visibility。將它的值設(shè)為 hidden 將隱藏我們的元素。如同 opacity 屬性,被隱藏的元素依然會(huì)對(duì)我們的網(wǎng)頁(yè)布局起作用。與 opacity 唯一不同的是它不會(huì)響應(yīng)任何用戶交互。此外,元素在讀屏軟件中也會(huì)被隱藏。

          這個(gè)屬性也能夠?qū)崿F(xiàn)動(dòng)畫效果,只要它的初始和結(jié)束狀態(tài)不一樣。這確保了 visibility 狀態(tài)切換之間的過(guò)渡動(dòng)畫可以是時(shí)間平滑的(事實(shí)上可以用這一點(diǎn)來(lái)用 hidden 實(shí)現(xiàn)元素的延遲顯示和隱藏——譯者注)。

          .hide {
           visibility: hidden;}

          下面的例子演示了 visibility 與 opacity 有怎樣的不同:

          看 @SitePoint 提供的例子“用 visibility 隱藏元素”

          注意,如果一個(gè)元素的 visibility 被設(shè)置為 hidden,同時(shí)想要顯示它的某個(gè)子孫元素,只要將那個(gè)元素的 visibility 顯式設(shè)置為 visible 即可(就如例子里面的 .o-hide p——譯者注)。嘗試只 hover 在隱藏元素上,不要 hover 在 p 標(biāo)簽里的數(shù)字上,你會(huì)發(fā)現(xiàn)你的鼠標(biāo)光標(biāo)沒(méi)有變成手指頭的樣子。此時(shí),你點(diǎn)擊鼠標(biāo),你的 click 事件也不會(huì)被觸發(fā)。

          而在 <div> 標(biāo)簽里面的 <p> 標(biāo)簽則依然可以捕獲所有的鼠標(biāo)事件。一旦你的鼠標(biāo)移動(dòng)到文字上,<div> 本身變得可見并且事件注冊(cè)也隨之生效。

          display

          display 屬性依照詞義真正隱藏元素。將 display 屬性設(shè)為 none 確保元素不可見并且連盒模型也不生成。使用這個(gè)屬性,被隱藏的元素不占據(jù)任何空間。不僅如此,一旦 display 設(shè)為 none 任何對(duì)該元素直接打用戶交互操作都不可能生效。此外,讀屏軟件也不會(huì)讀到元素的內(nèi)容。這種方式產(chǎn)生的效果就像元素完全不存在。

          任何這個(gè)元素的子孫元素也會(huì)被同時(shí)隱藏。為這個(gè)屬性添加過(guò)渡動(dòng)畫是無(wú)效的,它的任何不同狀態(tài)值之間的切換總是會(huì)立即生效。

          不過(guò)請(qǐng)注意,通過(guò) DOM 依然可以訪問(wèn)到這個(gè)元素。因此你可以通過(guò) DOM 來(lái)操作它,就像操作其他的元素。

          .hide {
           display: none;}

          看下面的例子:

          @SitePoint 提供的例子“用 display 隱藏元素”

          你將看到第二個(gè)塊元素內(nèi)有一個(gè) <p> 元素,它自己的 display 屬性被設(shè)置成 block,但是它依然不可見。這是 visibility:hidden 和 display:none 的另一個(gè)不同之處。在前一個(gè)例子里,將任何子孫元素 visibility 顯式設(shè)置成 visible 可以讓它變得可見,但是 display 不吃這一套,不管自身的 display值是什么,只要祖先元素的 display 是 none,它們就都不可見。

          現(xiàn)在,將鼠標(biāo)移到第一個(gè)塊元素上面幾次,然后點(diǎn)擊它。這個(gè)操作將讓第二個(gè)塊元素顯現(xiàn)出來(lái),它其中的數(shù)字將是一個(gè)大于 0 的數(shù)。這是因?yàn)椋丶词贡贿@樣設(shè)置成對(duì)用戶隱藏,還是可以通過(guò) JavaScript 來(lái)進(jìn)行操作。

          position

          假設(shè)有一個(gè)元素你想要與它交互,但是你又不想讓它影響你的網(wǎng)頁(yè)布局,沒(méi)有合適的屬性可以處理這種情況(opacity 和 visibility 影響布局, display 不影響布局但又無(wú)法直接交互——譯者注)。在這種情況下,你只能考慮將元素移出可視區(qū)域。這個(gè)辦法既不會(huì)影響布局,有能讓元素保持可以操作。下面是采用這 種辦法的 CSS:

          .hide {
           position: absolute;
           top: -9999px;
           left: -9999px;}

          下面的例子闡明了怎樣通過(guò)絕對(duì)定位的方式隱藏元素,并讓它和前面的那個(gè)例子效果一樣:

          看 @SitePoint 提供的例子“用 position 屬性隱藏元素”

          這種方法的主要原理是通過(guò)將元素的 top 和 left 設(shè)置成足夠大的負(fù)數(shù),使它在屏幕上不可見。采用這個(gè)技術(shù)的一個(gè)好處(或者潛在的缺點(diǎn))是用它隱藏的元素的內(nèi)容可以被讀屏軟件讀取。這完全可以理解,是因?yàn)槟阒皇菍⒃匾频娇梢晠^(qū)域外面讓用戶無(wú)法看到它。

          你得避免使用這個(gè)方法去隱藏任何可以獲得焦點(diǎn)的元素,因?yàn)槿绻敲醋觯?dāng)用戶讓那個(gè)元素獲得焦點(diǎn)時(shí),會(huì)導(dǎo)致一個(gè)不可預(yù)料的焦點(diǎn)切換。這個(gè)方法在創(chuàng)建 自定義復(fù)選框和單選按鈕時(shí)經(jīng)常被使用。(用 DOM 模擬復(fù)選框和單選按鈕,但用這個(gè)方法隱藏真正的 checkbox 和 radio 元素來(lái)“接收”焦點(diǎn)切換——譯者注)

          clip-path

          隱藏元素的另一種方法是通過(guò)剪裁它們來(lái)實(shí)現(xiàn)。在以前,這可以通過(guò) clip 屬性來(lái)實(shí)現(xiàn),但是這個(gè)屬性被廢棄了,換成一個(gè)更好的屬性叫做 clip-path。Nitish Kumar 最近在 SitePoint 發(fā)表了“介紹 clicp-path 屬性”這篇文章,通過(guò)閱讀它可以了解這個(gè)屬性的更多高級(jí)用法。

          記住,clip-path 屬性還沒(méi)有在 IE 或者 Edge 下被完全支持。如果要在你的 clip-path 中使用外部的 SVG 文件,瀏覽器支持度還要更低。使用 clip-path 屬性來(lái)隱藏元素的代碼看起來(lái)如下:

          .hide {
           clip-path: polygon(0px 0px,0px 0px,0px 0px,0px 0px);}

          下面是一個(gè)實(shí)際使用它的例子:

          看 @SitePoint 提供的例子“用 clip-path 屬性隱藏元素”

          如果你把鼠標(biāo)懸停在第一個(gè)元素上,它依然可以影響第二個(gè)元素,盡管第二個(gè)元素已經(jīng)通過(guò) clip-path 隱藏了。如果你點(diǎn)擊它,它會(huì)移除用來(lái)隱藏的 class,讓我們的元素從那個(gè)位置顯現(xiàn)出來(lái)。被隱藏元素中的文字仍然能夠通過(guò)讀屏軟件讀取,許多 WordPress 站點(diǎn)使用 clip-path 或者之前的 clip來(lái)實(shí)現(xiàn)專門為讀屏軟件提供的文字。

          雖然我們的元素自身不再顯示,它也依然占據(jù)本該占據(jù)的矩形大小,它周圍的元素的行為就如同它可見時(shí)一樣。記住用戶交互例如鼠標(biāo)懸停或者點(diǎn)擊在剪裁區(qū) 域之外也不可能生效。在我們的例子里,剪裁區(qū)大小為零,這意味著用戶將不能與隱藏的元素直接交互。此外,這個(gè)屬性能夠使用各種過(guò)渡動(dòng)畫來(lái)實(shí)現(xiàn)不同的效果。

          結(jié)論

          在這篇教程里,我們看了 5 種不同的通過(guò) CSS 隱藏元素的方法。每一種方法都與其他幾種有一點(diǎn)區(qū)別。知道你想要實(shí)現(xiàn)什么有助于你決定采用哪一個(gè)屬性,隨著時(shí)間推移,你就能根據(jù)實(shí)際需求本能地選擇最佳方式了。


          主站蜘蛛池模板: 国产产一区二区三区久久毛片国语| 国模极品一区二区三区| 亚洲乱码av中文一区二区| 色综合视频一区二区三区 | 国产精品无码亚洲一区二区三区 | 亚洲欧美日韩一区二区三区在线 | 日本免费电影一区| 亚洲av无码不卡一区二区三区| 国产一区二区三区内射高清| 国产精品香蕉在线一区| 一区二区视频在线播放| 伊人色综合一区二区三区| 国产精品成人一区二区| 夜色阁亚洲一区二区三区| 国产一区二区三区美女| 国产未成女一区二区三区 | 精品日韩在线视频一区二区三区 | 国产精品一区二区久久乐下载| 亚洲午夜精品一区二区公牛电影院 | 女女同性一区二区三区四区| 中文字幕日韩精品一区二区三区| 91无码人妻精品一区二区三区L| 久久青草国产精品一区| 少妇特黄A一区二区三区| 三上悠亚亚洲一区高清| 国产在线精品一区二区不卡| 中文字幕久久久久一区| 日本一区二区三区精品中文字幕| 美女一区二区三区| 亚洲一区二区三区免费视频| 精品女同一区二区三区免费站| 91精品一区二区| 精品久久久中文字幕一区| 白丝爆浆18禁一区二区三区| 一区二区三区在线播放| 亚洲日本一区二区三区在线 | 精品亚洲一区二区三区在线播放| 久久精品中文字幕一区| 国产午夜精品一区理论片| 亚洲国产日韩在线一区| 国产精品免费视频一区|