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

用 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)。

Visibility

第二個要說的屬性是visibility歌懒。將它的值設為hidden將隱藏我們的元素啦桌。如同opacity屬性,被隱藏的元素依然會對我們的網頁布局起作用及皂。與opacity唯一不同的是它不會響應任何用戶交互甫男。此外,元素在讀屏軟件中也會被隱藏验烧。

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

.hide { visibility: hidden; }

注意若治,如果一個元素的visibility被設置為hidden,同時想要顯示它的某個子孫元素感混,只要將那個元素的visibility顯式設置為visible即可端幼。嘗試只 hover 在隱藏元素上,不要 hover 在 p 標簽里的數(shù)字上弧满,你會發(fā)現(xiàn)你的鼠標光標沒有變成手指頭的樣子婆跑。此時,你點擊鼠標谱秽,你的 click 事件也不會被觸發(fā)洽蛀。而在標簽里面的標簽則依然可以捕獲所有的鼠標事件。一旦你的鼠標移動到文字上疟赊,本身變得可見并且事件注冊也隨之生效郊供。

Display

display屬性依照詞義真正隱藏元素。將display屬性設為none確保元素不可見并且連盒模型也不生成近哟。使用這個屬性驮审,被隱藏的元素不占據任何空間。不僅如此吉执,一旦display設為none任何對該元素直接打用戶交互操作都不可能生效疯淫。此外,讀屏軟件也不會讀到元素的內容戳玫。這種方式產生的效果就像元素完全不存在熙掺。任何這個元素的子孫元素也會被同時隱藏。為這個屬性添加過渡動畫是無效的咕宿,它的任何不同狀態(tài)值之間的切換總是會立即生效币绩。

不過請注意蜡秽,通過 DOM 依然可以訪問到這個元素。因此你可以通過 DOM 來操作它缆镣,就像操作其他的元素芽突。

.hide { display: none; }

這是visibility:hidden和display:none的另一個不同之處。在前一個例子里董瞻,將任何子孫元素visibility顯式設置成visible可以讓它變得可見寞蚌,但是display不吃這一套,不管自身的display值是什么钠糊,只要祖先元素的display是none挟秤,它們就都不可見。

Position

假設有一個元素你想要與它交互眠蚂,但是你又不想讓它影響你的網頁布局煞聪,沒有合適的屬性可以處理這種情況(opacity 和 visibility 影響布局, display 不影響布局但又無法直接交互——譯者注)逝慧。在這種情況下昔脯,你只能考慮將元素移出可視區(qū)域。這個辦法既不會影響布局笛臣,有能讓元素保持可以操作云稚。下面是采用這種辦法的 CSS:

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

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

結論

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

?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末牵敷,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子法希,更是在濱河造成了極大的恐慌枷餐,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,657評論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件苫亦,死亡現(xiàn)場離奇詭異毛肋,居然都是意外死亡奕锌,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,889評論 3 394
  • 文/潘曉璐 我一進店門村生,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人饼丘,你說我怎么就攤上這事趁桃。” “怎么了肄鸽?”我有些...
    開封第一講書人閱讀 164,057評論 0 354
  • 文/不壞的土叔 我叫張陵卫病,是天一觀的道長。 經常有香客問我典徘,道長蟀苛,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,509評論 1 293
  • 正文 為了忘掉前任逮诲,我火速辦了婚禮帜平,結果婚禮上,老公的妹妹穿的比我還像新娘梅鹦。我一直安慰自己裆甩,他們只是感情好,可當我...
    茶點故事閱讀 67,562評論 6 392
  • 文/花漫 我一把揭開白布齐唆。 她就那樣靜靜地躺著嗤栓,像睡著了一般。 火紅的嫁衣襯著肌膚如雪箍邮。 梳的紋絲不亂的頭發(fā)上茉帅,一...
    開封第一講書人閱讀 51,443評論 1 302
  • 那天,我揣著相機與錄音锭弊,去河邊找鬼堪澎。 笑死,一個胖子當著我的面吹牛廷蓉,可吹牛的內容都是我干的全封。 我是一名探鬼主播,決...
    沈念sama閱讀 40,251評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼桃犬,長吁一口氣:“原來是場噩夢啊……” “哼刹悴!你這毒婦竟也來了?” 一聲冷哼從身側響起攒暇,我...
    開封第一講書人閱讀 39,129評論 0 276
  • 序言:老撾萬榮一對情侶失蹤土匀,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后形用,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體就轧,經...
    沈念sama閱讀 45,561評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡证杭,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,779評論 3 335
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了妒御。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片解愤。...
    茶點故事閱讀 39,902評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖乎莉,靈堂內的尸體忽然破棺而出送讲,到底是詐尸還是另有隱情,我是刑警寧澤惋啃,帶...
    沈念sama閱讀 35,621評論 5 345
  • 正文 年R本政府宣布哼鬓,位于F島的核電站,受9級特大地震影響边灭,放射性物質發(fā)生泄漏异希。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,220評論 3 328
  • 文/蒙蒙 一绒瘦、第九天 我趴在偏房一處隱蔽的房頂上張望称簿。 院中可真熱鬧,春花似錦惰帽、人聲如沸予跌。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,838評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽券册。三九已至,卻和暖如春垂涯,著一層夾襖步出監(jiān)牢的瞬間烁焙,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,971評論 1 269
  • 我被黑心中介騙來泰國打工耕赘, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留骄蝇,地道東北人。 一個月前我還...
    沈念sama閱讀 48,025評論 2 370
  • 正文 我出身青樓操骡,卻偏偏與公主長得像九火,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子册招,可洞房花燭夜當晚...
    茶點故事閱讀 44,843評論 2 354

推薦閱讀更多精彩內容