英文原文:Five Ways to Hide Elements in CSS
作者:Baljeet Rathi
譯者:十年蹤跡
原文地址:http://www.zcfy.cc/article/457
用 CSS 隱藏頁面元素有許多種方法。你可以將opacity設(shè)為0、將visibility設(shè)為hidden、將display設(shè)為none或者將position設(shè)為absolute然后將位置設(shè)到不可見區(qū)域。
你有沒有想過,為什么我們要有這么多技術(shù)來隱藏元素,而它們看起來都實(shí)現(xiàn)的是同樣的效果?每一種方法實(shí)際上與其他方法之間都有一些細(xì)微的不同,這些不同決定了在一個特定的場合下使用哪一個方法。這篇教程將覆蓋到那些你需要記住的細(xì)小不同點(diǎn),讓你根據(jù)不同情況選擇上面這些方法中適合的方法來隱藏元素。
Opacity
opacity屬性的意思是設(shè)置一個元素的透明度。它不是為改變元素的邊界框(bounding box)而設(shè)計(jì)的。這意味著將opacity設(shè)為0只能從視覺上隱藏元素。而元素本身依然占據(jù)它自己的位置并對網(wǎng)頁的布局起作用。它也將響應(yīng)用戶交互。
.hide {
opacity: 0;
}
如果你打算使用opacity屬性在讀屏軟件中隱藏元素,很不幸,你并不能如愿。元素和它所有的內(nèi)容會被讀屏軟件閱讀,就像網(wǎng)頁上的其他元素那樣。換句話說,元素的行為就和它們不透明時一致。
我還要提醒一句,opacity屬性可以用來實(shí)現(xiàn)一些效果很棒的動畫。任何opacity屬性值小于1的元素也會創(chuàng)建一個新的堆疊上下文(stacking context)。
看下面的例子:
看 @SitePoint 提供的例子“用 opacity 隱藏元素”
當(dāng)你的鼠標(biāo)移到被隱藏的第 2 個的區(qū)塊上,元素狀態(tài)平滑地從完全透明過渡到完全不透明。區(qū)塊也將cursor屬性設(shè)置為了pointer,這說明了用戶可以與它交互。
Visibility
第二個要說的屬性是visibility。將它的值設(shè)為hidden將隱藏我們的元素。如同opacity屬性,被隱藏的元素依然會對我們的網(wǎng)頁布局起作用。與opacity唯一不同的是它不會響應(yīng)任何用戶交互。此外,元素在讀屏軟件中也會被隱藏。
這個屬性也能夠?qū)崿F(xiàn)動畫效果,只要它的初始和結(jié)束狀態(tài)不一樣。這確保了 visibility 狀態(tài)切換之間的過渡動畫可以是時間平滑的(事實(shí)上可以用這一點(diǎn)來用 hidden 實(shí)現(xiàn)元素的延遲顯示和隱藏——譯者注)。
.hide {
visibility: hidden;
}
下面的例子演示了visibility與opacity有怎樣的不同:
看 @SitePoint 提供的例子“用 visibility 隱藏元素”
注意,如果一個元素的visibility被設(shè)置為hidden,同時想要顯示它的某個子孫元素,只要將那個元素的visibility顯式設(shè)置為visible即可(就如例子里面的 .o-hide p——譯者注)。嘗試只 hover 在隱藏元素上,不要 hover 在p標(biāo)簽里的數(shù)字上,你會發(fā)現(xiàn)你的鼠標(biāo)光標(biāo)沒有變成手指頭的樣子。此時,你點(diǎn)擊鼠標(biāo),你的 click 事件也不會被觸發(fā)。
而在<div>標(biāo)簽里面的<p>標(biāo)簽則依然可以捕獲所有的鼠標(biāo)事件。一旦你的鼠標(biāo)移動到文字上,<div>本身變得可見并且事件注冊也隨之生效。
Display
display屬性依照詞義真正隱藏元素。將display屬性設(shè)為none確保元素不可見并且連盒模型也不生成。使用這個屬性,被隱藏的元素不占據(jù)任何空間。不僅如此,一旦display設(shè)為none任何對該元素直接打用戶交互操作都不可能生效。此外,讀屏軟件也不會讀到元素的內(nèi)容。這種方式產(chǎn)生的效果就像元素完全不存在。
任何這個元素的子孫元素也會被同時隱藏。為這個屬性添加過渡動畫是無效的,它的任何不同狀態(tài)值之間的切換總是會立即生效。
不過請注意,通過 DOM 依然可以訪問到這個元素。因此你可以通過 DOM 來操作它,就像操作其他的元素。
.hide {
display: none;
}
看下面的例子:
@SitePoint 提供的例子“用 display 隱藏元素”
你將看到第二個塊元素內(nèi)有一個<p>元素,它自己的display屬性被設(shè)置成block,但是它依然不可見。這是visibility:hidden和display:none的另一個不同之處。在前一個例子里,將任何子孫元素visibility顯式設(shè)置成visible可以讓它變得可見,但是display不吃這一套,不管自身的display值是什么,只要祖先元素的display是none,它們就都不可見。
現(xiàn)在,將鼠標(biāo)移到第一個塊元素上面幾次,然后點(diǎn)擊它。這個操作將讓第二個塊元素顯現(xiàn)出來,它其中的數(shù)字將是一個大于 0 的數(shù)。這是因?yàn)?,元素即使被這樣設(shè)置成對用戶隱藏,還是可以通過 JavaScript 來進(jìn)行操作。
Position
假設(shè)有一個元素你想要與它交互,但是你又不想讓它影響你的網(wǎng)頁布局,沒有合適的屬性可以處理這種情況(opacity和visibility影響布局, display不影響布局但又無法直接交互——譯者注)。在這種情況下,你只能考慮將元素移出可視區(qū)域。這個辦法既不會影響布局,有能讓元素保持可以操作。下面是采用這種辦法的 CSS:
.hide {
position: absolute;
top: -9999px;
left: -9999px;
}
下面的例子闡明了怎樣通過絕對定位的方式隱藏元素,并讓它和前面的那個例子效果一樣:
看 @SitePoint 提供的例子“用 position 屬性隱藏元素”
這種方法的主要原理是通過將元素的top和left設(shè)置成足夠大的負(fù)數(shù),使它在屏幕上不可見。采用這個技術(shù)的一個好處(或者潛在的缺點(diǎn))是用它隱藏的元素的內(nèi)容可以被讀屏軟件讀取。這完全可以理解,是因?yàn)槟阒皇菍⒃匾频娇梢晠^(qū)域外面讓用戶無法看到它。
你得避免使用這個方法去隱藏任何可以獲得焦點(diǎn)的元素,因?yàn)槿绻敲醋觯?dāng)用戶讓那個元素獲得焦點(diǎn)時,會導(dǎo)致一個不可預(yù)料的焦點(diǎn)切換。這個方法在創(chuàng)建自定義復(fù)選框和單選按鈕時經(jīng)常被使用。(用 DOM 模擬復(fù)選框和單選按鈕,但用這個方法隱藏真正的checkbox和radio元素來“接收”焦點(diǎn)切換——譯者注)
Clip-path
隱藏元素的另一種方法是通過剪裁它們來實(shí)現(xiàn)。在以前,這可以通過clip屬性來實(shí)現(xiàn),但是這個屬性被廢棄了,換成一個更好的屬性叫做clip-path。Nitish Kumar 最近在 SitePoint 發(fā)表了“介紹clicp-path屬性”這篇文章,通過閱讀它可以了解這個屬性的更多高級用法。
記住,clip-path屬性還沒有在 IE 或者 Edge 下被完全支持。如果要在你的clip-path中使用外部的 SVG 文件,瀏覽器支持度還要更低。使用clip-path屬性來隱藏元素的代碼看起來如下:
.hide {
clip-path: polygon(0px 0px,0px 0px,0px 0px,0px 0px);
}
下面是一個實(shí)際使用它的例子:
看 @SitePoint 提供的例子“用 clip-path 屬性隱藏元素”
如果你把鼠標(biāo)懸停在第一個元素上,它依然可以影響第二個元素,盡管第二個元素已經(jīng)通過clip-path隱藏了。如果你點(diǎn)擊它,它會移除用來隱藏的 class,讓我們的元素從那個位置顯現(xiàn)出來。被隱藏元素中的文字仍然能夠通過讀屏軟件讀取,許多 WordPress 站點(diǎn)使用clip-path或者之前的clip來實(shí)現(xiàn)專門為讀屏軟件提供的文字。
雖然我們的元素自身不再顯示,它也依然占據(jù)本該占據(jù)的矩形大小,它周圍的元素的行為就如同它可見時一樣。記住用戶交互例如鼠標(biāo)懸停或者點(diǎn)擊在剪裁區(qū)域之外也不可能生效。在我們的例子里,剪裁區(qū)大小為零,這意味著用戶將不能與隱藏的元素直接交互。此外,這個屬性能夠使用各種過渡動畫來實(shí)現(xiàn)不同的效果。
結(jié)論
在這篇教程里,我們看了 5 種不同的通過 CSS 隱藏元素的方法。每一種方法都與其他幾種有一點(diǎn)區(qū)別。知道你想要實(shí)現(xiàn)什么有助于你決定采用哪一個屬性,隨著時間推移,你就能根據(jù)實(shí)際需求本能地選擇最佳方式了。如果你對于隱藏元素的這些方法還有任何問題,請?jiān)谠u論中留言。