用 CSS 隱藏頁面元素有許多種方法。你能夠將 opacity
設爲 0
、將 visibility
設爲hidden
、將 display
設爲 none
或者將 position
設爲 absolute
而後將位置設到不可見區域。css
你有沒有想過,爲何咱們要有這麼多技術來隱藏元素,而它們看起來都實現的是一樣的效果?每一種方法實際上與其餘方法之間都有一些細微的不一樣,這些不一樣決定了在一個特定的場合下使用哪個方法。這篇教程將覆蓋到那些你須要記住的細小不一樣點,讓你根據不一樣狀況選擇上面這些方法中適合的方法來隱藏元素。瀏覽器
opacity
屬性的意思是設置一個元素的透明度。它不是爲改變元素的邊界框(bounding box)而設計的。這意味着將 opacity 設爲 0 只能從視覺上隱藏元素。而元素自己依然佔據它本身的位置並對網頁的佈局起做用。它也將響應用戶交互。ide
.hide { opacity: 0; }
若是你打算使用 opacity
屬性在讀屏軟件中隱藏元素,很不幸,你並不能如願。元素和它全部的內容會被讀屏軟件閱讀,就像網頁上的其餘元素那樣。換句話說,元素的行爲就和它們不透明時一致。wordpress
我還要提醒一句,opacity
屬性能夠用來實現一些效果很棒的動畫。任何 opacity
屬性值小於1
的元素也會建立一個新的堆疊上下文(stacking context)。佈局
看下面的例子:性能
看 @SitePoint 提供的例子「用 opacity 隱藏元素」動畫
當你的鼠標移到被隱藏的第 2 個的區塊上,元素狀態平滑地從徹底透明過渡到徹底不透明。區塊也將cursor
屬性設置爲了 pointer
,這說明了用戶能夠與它交互。spa
第二個要說的屬性是 visibility
。將它的值設爲 hidden
將隱藏咱們的元素。如同 opacity
屬性,被隱藏的元素依然會對咱們的網頁佈局起做用。與 opacity
惟一不一樣的是它不會響應任何用戶交互。此外,元素在讀屏軟件中也會被隱藏。設計
這個屬性也可以實現動畫效果,只要它的初始和結束狀態不同。這確保了 visibility 狀態切換之間的過渡動畫能夠是時間平滑的(事實上能夠用這一點來用 hidden 實現元素的延遲顯示和隱藏——譯者注)。code
.hide { visibility: hidden; }
下面的例子演示了 visibility
與 opacity
有怎樣的不一樣:
看 @SitePoint 提供的例子「用 visibility 隱藏元素」
注意,若是一個元素的 visibility
被設置爲 hidden
,同時想要顯示它的某個子孫元素,只要將那個元素的 visibility
顯式設置爲 visible
便可(就如例子裏面的 .o-hide p——譯者注)。嘗試只 hover 在隱藏元素上,不要 hover 在 p 標籤裏的數字上,你會發現你的鼠標光標沒有變成手指頭的樣子。此時,你點擊鼠標,你的 click 事件也不會被觸發。
而在 <div>
標籤裏面的 <p>
標籤則依然能夠捕獲全部的鼠標事件。一旦你的鼠標移動到文字上,<div>
自己變得可見而且事件註冊也隨之生效。
display
屬性依照詞義真正隱藏元素。將 display
屬性設爲 none
確保元素不可見而且連盒模型也不生成。使用這個屬性,被隱藏的元素不佔據任何空間。不只如此,一旦 display
設爲none
任何對該元素直接打用戶交互操做都不可能生效。此外,讀屏軟件也不會讀到元素的內容。這種方式產生的效果就像元素徹底不存在。
任何這個元素的子孫元素也會被同時隱藏。爲這個屬性添加過渡動畫是無效的,它的任何不一樣狀態值之間的切換老是會當即生效。
不過請注意,經過 DOM 依然能夠訪問到這個元素。所以你能夠經過 DOM 來操做它,就像操做其餘的元素。
.hide { display: none; }
看下面的例子:
@SitePoint 提供的例子「用 display 隱藏元素」
你將看到第二個塊元素內有一個 <p>
元素,它本身的 display
屬性被設置成 block
,可是它依然不可見。這是 visibility:hidden
和 display:none
的另外一個不一樣之處。在前一個例子裏,將任何子孫元素 visibility
顯式設置成 visible
可讓它變得可見,可是 display
不吃這一套,無論自身的 display
值是什麼,只要祖先元素的 display
是 none
,它們就都不可見。
如今,將鼠標移到第一個塊元素上面幾回,而後點擊它。這個操做將讓第二個塊元素顯現出來,它其中的數字將是一個大於 0 的數。這是由於,元素即便被這樣設置成對用戶隱藏,仍是能夠經過 JavaScript 來進行操做。
假設有一個元素你想要與它交互,可是你又不想讓它影響你的網頁佈局,沒有合適的屬性能夠處理這種狀況(opacity 和 visibility 影響佈局, display 不影響佈局但又沒法直接交互——譯者注)。在這種狀況下,你只能考慮將元素移出可視區域。這個辦法既不會影響佈局,有能讓元素保持能夠操做。下面是採用這種辦法的 CSS:
.hide { position: absolute; top: -9999px; left: -9999px; }
下面的例子闡明瞭怎樣經過絕對定位的方式隱藏元素,並讓它和前面的那個例子效果同樣:
看 @SitePoint 提供的例子「用 position 屬性隱藏元素」
這種方法的主要原理是經過將元素的 top 和 left 設置成足夠大的負數,使它在屏幕上不可見。採用這個技術的一個好處(或者潛在的缺點)是用它隱藏的元素的內容能夠被讀屏軟件讀取。這徹底能夠理解,是由於你只是將元素移到可視區域外面讓用戶沒法看到它。
你得避免使用這個方法去隱藏任何能夠得到焦點的元素,由於若是那麼作,當用戶讓那個元素得到焦點時,會致使一個不可預料的焦點切換。這個方法在建立自定義複選框和單選按鈕時常常被使用。(用 DOM 模擬複選框和單選按鈕,但用這個方法隱藏真正的 checkbox 和 radio 元素來「接收」焦點切換——譯者注)
隱藏元素的另外一種方法是經過剪裁它們來實現。在之前,這能夠經過 clip
屬性來實現,可是這個屬性被廢棄了,換成一個更好的屬性叫作 clip-path
。Nitish Kumar 最近在 SitePoint 發表了「介紹clicp-path
屬性」這篇文章,經過閱讀它能夠了解這個屬性的更多高級用法。
記住,clip-path
屬性還沒有在 IE 或者 Edge 下被徹底支持。若是要在你的 clip-path
中使用外部的 SVG 文件,瀏覽器支持度還要更低。使用 clip-path
屬性來隱藏元素的代碼看起來以下:
.hide { clip-path: polygon(0px 0px,0px 0px,0px 0px,0px 0px); }
下面是一個實際使用它的例子:
看 @SitePoint 提供的例子「用 clip-path 屬性隱藏元素」
若是你把鼠標懸停在第一個元素上,它依然能夠影響第二個元素,儘管第二個元素已經經過 clip-path
隱藏了。若是你點擊它,它會移除用來隱藏的 class,讓咱們的元素從那個位置顯現出來。被隱藏元素中的文字仍然可以經過讀屏軟件讀取,許多 WordPress 站點使用 clip-path
或者以前的clip
來實現專門爲讀屏軟件提供的文字。
雖然咱們的元素自身再也不顯示,它也依然佔據本該佔據的矩形大小,它周圍的元素的行爲就如同它可見時同樣。記住用戶交互例如鼠標懸停或者點擊在剪裁區域以外也不可能生效。在咱們的例子裏,剪裁區大小爲零,這意味着用戶將不能與隱藏的元素直接交互。此外,這個屬性可以使用各類過渡動畫來實現不一樣的效果。
在這篇教程裏,咱們看了 5 種不一樣的經過 CSS 隱藏元素的方法。每一種方法都與其餘幾種有一點區別。知道你想要實現什麼有助於你決定採用哪個屬性,隨着時間推移,你就能根據實際需求本能地選擇最佳方式了。若是你對於隱藏元素的這些方法還有任何問題,請在評論中留言。