用 CSS 隱藏頁面元素的 5 種方法

英文原文:Five Ways to Hide Elements in CSS
作者:Baljeet Rathi
譯者:十年蹤跡
原文地址:http://www.zcfy.cc/article/457

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

你有沒有想過,為什么我們要有這么多技術來隱藏元素鸣剪,而它們看起來都實現(xiàn)的是同樣的效果组底?每一種方法實際上與其他方法之間都有一些細微的不同丈积,這些不同決定了在一個特定的場合下使用哪一個方法。這篇教程將覆蓋到那些你需要記住的細小不同點债鸡,讓你根據不同情況選擇上面這些方法中適合的方法來隱藏元素江滨。

Opacity

opacity屬性的意思是設置一個元素的透明度。它不是為改變元素的邊界框(bounding box)而設計的厌均。這意味著將opacity設為0只能從視覺上隱藏元素唬滑。而元素本身依然占據它自己的位置并對網頁的布局起作用。它也將響應用戶交互棺弊。

.hide {
  opacity: 0;
}

如果你打算使用opacity屬性在讀屏軟件中隱藏元素晶密,很不幸,你并不能如愿模她。元素和它所有的內容會被讀屏軟件閱讀稻艰,就像網頁上的其他元素那樣。換句話說侈净,元素的行為就和它們不透明時一致尊勿。

我還要提醒一句,opacity屬性可以用來實現(xiàn)一些效果很棒的動畫用狱。任何opacity屬性值小于1的元素也會創(chuàng)建一個新的堆疊上下文(stacking context)运怖。

看下面的例子:

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

當你的鼠標移到被隱藏的第 2 個的區(qū)塊上,元素狀態(tài)平滑地從完全透明過渡到完全不透明夏伊。區(qū)塊也將cursor屬性設置為了pointer摇展,這說明了用戶可以與它交互。

Visibility

第二個要說的屬性是visibility溺忧。將它的值設為hidden將隱藏我們的元素咏连。如同opacity屬性,被隱藏的元素依然會對我們的網頁布局起作用鲁森。與opacity唯一不同的是它不會響應任何用戶交互祟滴。此外,元素在讀屏軟件中也會被隱藏歌溉。

這個屬性也能夠實現(xiàn)動畫效果垄懂,只要它的初始和結束狀態(tài)不一樣。這確保了 visibility 狀態(tài)切換之間的過渡動畫可以是時間平滑的(事實上可以用這一點來用 hidden 實現(xiàn)元素的延遲顯示和隱藏——譯者注)痛垛。

.hide {
   visibility: hidden;
}

下面的例子演示了visibilityopacity有怎樣的不同:

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

注意草慧,如果一個元素的visibility被設置為hidden,同時想要顯示它的某個子孫元素匙头,只要將那個元素的visibility顯式設置為visible即可(就如例子里面的 .o-hide p——譯者注)漫谷。嘗試只 hover 在隱藏元素上,不要 hover 在p標簽里的數(shù)字上蹂析,你會發(fā)現(xiàn)你的鼠標光標沒有變成手指頭的樣子舔示。此時碟婆,你點擊鼠標,你的 click 事件也不會被觸發(fā)惕稻。

而在<div>標簽里面的<p>標簽則依然可以捕獲所有的鼠標事件竖共。一旦你的鼠標移動到文字上,<div>本身變得可見并且事件注冊也隨之生效缩宜。

Display

display屬性依照詞義真正隱藏元素肘迎。將display屬性設為none確保元素不可見并且連盒模型也不生成。使用這個屬性锻煌,被隱藏的元素不占據任何空間。不僅如此姻蚓,一旦display設為none任何對該元素直接打用戶交互操作都不可能生效宋梧。此外,讀屏軟件也不會讀到元素的內容狰挡。這種方式產生的效果就像元素完全不存在捂龄。

任何這個元素的子孫元素也會被同時隱藏。為這個屬性添加過渡動畫是無效的加叁,它的任何不同狀態(tài)值之間的切換總是會立即生效倦沧。

不過請注意,通過 DOM 依然可以訪問到這個元素它匕。因此你可以通過 DOM 來操作它展融,就像操作其他的元素。

.hide {
   display: none;
}

看下面的例子:

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

你將看到第二個塊元素內有一個<p>元素豫柬,它自己的display屬性被設置成block告希,但是它依然不可見。這是visibility:hiddendisplay:none的另一個不同之處烧给。在前一個例子里燕偶,將任何子孫元素visibility顯式設置成visible可以讓它變得可見,但是display不吃這一套础嫡,不管自身的display值是什么指么,只要祖先元素的displaynone,它們就都不可見榴鼎。

現(xiàn)在伯诬,將鼠標移到第一個塊元素上面幾次,然后點擊它檬贰。這個操作將讓第二個塊元素顯現(xiàn)出來姑廉,它其中的數(shù)字將是一個大于 0 的數(shù)。這是因為翁涤,元素即使被這樣設置成對用戶隱藏桥言,還是可以通過 JavaScript 來進行操作萌踱。

Position

假設有一個元素你想要與它交互,但是你又不想讓它影響你的網頁布局号阿,沒有合適的屬性可以處理這種情況(opacityvisibility影響布局并鸵, display不影響布局但又無法直接交互——譯者注)。在這種情況下扔涧,你只能考慮將元素移出可視區(qū)域园担。這個辦法既不會影響布局,有能讓元素保持可以操作枯夜。下面是采用這種辦法的 CSS:

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

下面的例子闡明了怎樣通過絕對定位的方式隱藏元素弯汰,并讓它和前面的那個例子效果一樣:

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

這種方法的主要原理是通過將元素的topleft設置成足夠大的負數(shù),使它在屏幕上不可見湖雹。采用這個技術的一個好處(或者潛在的缺點)是用它隱藏的元素的內容可以被讀屏軟件讀取咏闪。這完全可以理解,是因為你只是將元素移到可視區(qū)域外面讓用戶無法看到它摔吏。

你得避免使用這個方法去隱藏任何可以獲得焦點的元素鸽嫂,因為如果那么做,當用戶讓那個元素獲得焦點時征讲,會導致一個不可預料的焦點切換据某。這個方法在創(chuàng)建自定義復選框和單選按鈕時經常被使用。(用 DOM 模擬復選框和單選按鈕诗箍,但用這個方法隱藏真正的checkboxradio元素來“接收”焦點切換——譯者注)

Clip-path

隱藏元素的另一種方法是通過剪裁它們來實現(xiàn)癣籽。在以前,這可以通過clip屬性來實現(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);
}

下面是一個實際使用它的例子:

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

如果你把鼠標懸停在第一個元素上首昔,它依然可以影響第二個元素寡喝,盡管第二個元素已經通過clip-path隱藏了。如果你點擊它勒奇,它會移除用來隱藏的 class预鬓,讓我們的元素從那個位置顯現(xiàn)出來。被隱藏元素中的文字仍然能夠通過讀屏軟件讀取赊颠,許多 WordPress 站點使用clip-path或者之前的clip來實現(xiàn)專門為讀屏軟件提供的文字格二。

雖然我們的元素自身不再顯示劈彪,它也依然占據本該占據的矩形大小,它周圍的元素的行為就如同它可見時一樣顶猜。記住用戶交互例如鼠標懸筒着或者點擊在剪裁區(qū)域之外也不可能生效。在我們的例子里长窄,剪裁區(qū)大小為零滔吠,這意味著用戶將不能與隱藏的元素直接交互。此外挠日,這個屬性能夠使用各種過渡動畫來實現(xiàn)不同的效果疮绷。

結論

在這篇教程里,我們看了 5 種不同的通過 CSS 隱藏元素的方法肆资。每一種方法都與其他幾種有一點區(qū)別矗愧。知道你想要實現(xiàn)什么有助于你決定采用哪一個屬性,隨著時間推移郑原,你就能根據實際需求本能地選擇最佳方式了。如果你對于隱藏元素的這些方法還有任何問題夜涕,請在評論中留言犯犁。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市女器,隨后出現(xiàn)的幾起案子酸役,更是在濱河造成了極大的恐慌,老刑警劉巖驾胆,帶你破解...
    沈念sama閱讀 206,311評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件涣澡,死亡現(xiàn)場離奇詭異,居然都是意外死亡丧诺,警方通過查閱死者的電腦和手機入桂,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,339評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來驳阎,“玉大人抗愁,你說我怎么就攤上這事『峭恚” “怎么了蜘腌?”我有些...
    開封第一講書人閱讀 152,671評論 0 342
  • 文/不壞的土叔 我叫張陵,是天一觀的道長饵隙。 經常有香客問我撮珠,道長,這世上最難降的妖魔是什么金矛? 我笑而不...
    開封第一講書人閱讀 55,252評論 1 279
  • 正文 為了忘掉前任芯急,我火速辦了婚禮勺届,結果婚禮上,老公的妹妹穿的比我還像新娘志于。我一直安慰自己涮因,他們只是感情好,可當我...
    茶點故事閱讀 64,253評論 5 371
  • 文/花漫 我一把揭開白布伺绽。 她就那樣靜靜地躺著养泡,像睡著了一般。 火紅的嫁衣襯著肌膚如雪奈应。 梳的紋絲不亂的頭發(fā)上澜掩,一...
    開封第一講書人閱讀 49,031評論 1 285
  • 那天,我揣著相機與錄音杖挣,去河邊找鬼肩榕。 笑死,一個胖子當著我的面吹牛惩妇,可吹牛的內容都是我干的株汉。 我是一名探鬼主播,決...
    沈念sama閱讀 38,340評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼歌殃,長吁一口氣:“原來是場噩夢啊……” “哼乔妈!你這毒婦竟也來了?” 一聲冷哼從身側響起氓皱,我...
    開封第一講書人閱讀 36,973評論 0 259
  • 序言:老撾萬榮一對情侶失蹤路召,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后波材,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體股淡,經...
    沈念sama閱讀 43,466評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 35,937評論 2 323
  • 正文 我和宋清朗相戀三年廷区,在試婚紗的時候發(fā)現(xiàn)自己被綠了唯灵。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,039評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡躲因,死狀恐怖早敬,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情大脉,我是刑警寧澤搞监,帶...
    沈念sama閱讀 33,701評論 4 323
  • 正文 年R本政府宣布,位于F島的核電站镰矿,受9級特大地震影響琐驴,放射性物質發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,254評論 3 307
  • 文/蒙蒙 一绝淡、第九天 我趴在偏房一處隱蔽的房頂上張望宙刘。 院中可真熱鬧,春花似錦牢酵、人聲如沸悬包。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,259評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽布近。三九已至,卻和暖如春丝格,著一層夾襖步出監(jiān)牢的瞬間撑瞧,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,485評論 1 262
  • 我被黑心中介騙來泰國打工显蝌, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留预伺,地道東北人。 一個月前我還...
    沈念sama閱讀 45,497評論 2 354
  • 正文 我出身青樓曼尊,卻偏偏與公主長得像酬诀,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子骆撇,可洞房花燭夜當晚...
    茶點故事閱讀 42,786評論 2 345

推薦閱讀更多精彩內容