利用CSS 隱藏頁(yè)面元素的幾種常用方法詳解

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

Opacity

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

.hide {
opacity: 0;
}

如果你打算使用 opacity 屬性在讀屏軟件中隱藏元素廉侧,很不幸,你并不能如愿篓足。元素和它所有的內(nèi)容會(huì)被讀屏軟件閱讀段誊,就像網(wǎng)頁(yè)上的其他元素那樣。換句話說(shuō)栈拖,元素的行為就和它們不透明時(shí)一致连舍。
我還要提醒一句,opacity 屬性可以用來(lái)實(shí)現(xiàn)一些效果很棒的動(dòng)畫(huà)涩哟。任何 opacity 屬性值小于 1 的元素也會(huì)創(chuàng)建一個(gè)新的堆疊上下文(stacking context)索赏。

Visibility

第二個(gè)要說(shuō)的屬性是 visibility。將它的值設(shè)為 hidden 將隱藏我們的元素贴彼。如同 opacity 屬性潜腻,被隱藏的元素依然會(huì)對(duì)我們的網(wǎng)頁(yè)布局起作用。與 opacity 唯一不同的是它不會(huì)響應(yīng)任何用戶(hù)交互器仗。此外融涣,元素在讀屏軟件中也會(huì)被隱藏童番。
這個(gè)屬性也能夠?qū)崿F(xiàn)動(dòng)畫(huà)效果,只要它的初始和結(jié)束狀態(tài)不一樣威鹿。這確保了 visibility 狀態(tài)切換之間的過(guò)渡動(dòng)畫(huà)可以是時(shí)間平滑的(事實(shí)上可以用這一點(diǎn)來(lái)用 hidden 實(shí)現(xiàn)元素的延遲顯示和隱藏)剃斧。

.hide {
visibility: hidden;
}

注意,如果一個(gè)元素的 visibility 被設(shè)置為 hidden忽你,同時(shí)想要顯示它的某個(gè)子孫元素幼东,只要將那個(gè)元素的 visibility 顯式設(shè)置為 visible 即可。嘗試只 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> 本身變得可見(jiàn)并且事件注冊(cè)也隨之生效沛婴。

Display

display 屬性依照詞義真正隱藏元素吼畏。將 display 屬性設(shè)為 none 確保元素不可見(jiàn)并且連盒模型也不生成。使用這個(gè)屬性嘁灯,被隱藏的元素不占據(jù)任何空間泻蚊。不僅如此,一旦 display 設(shè)為 none 任何對(duì)該元素直接打用戶(hù)交互操作都不可能生效丑婿。此外性雄,讀屏軟件也不會(huì)讀到元素的內(nèi)容。這種方式產(chǎn)生的效果就像元素完全不存在羹奉。
任何這個(gè)元素的子孫元素也會(huì)被同時(shí)隱藏秒旋。為這個(gè)屬性添加過(guò)渡動(dòng)畫(huà)是無(wú)效的,它的任何不同狀態(tài)值之間的切換總是會(huì)立即生效诀拭。
不過(guò)請(qǐng)注意迁筛,通過(guò) DOM 依然可以訪問(wèn)到這個(gè)元素。因此你可以通過(guò) DOM 來(lái)操作它耕挨,就像操作其他的元素细卧。

.hide {
display: none;
}

不管自身的 display 值是什么,只要祖先元素的 display 是 none筒占,它們就都不可見(jiàn)贪庙。元素即使被這樣設(shè)置成對(duì)用戶(hù)隱藏,還是可以通過(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ò)將元素的 top 和 left 設(shè)置成足夠大的負(fù)數(shù),使它在屏幕上不可見(jiàn)滑沧。采用這個(gè)技術(shù)的一個(gè)好處(或者潛在的缺點(diǎn))是用它隱藏的元素的內(nèi)容可以被讀屏軟件讀取并村。這完全可以理解,是因?yàn)槟阒皇菍⒃匾频娇梢晠^(qū)域外面讓用戶(hù)無(wú)法看到它滓技。
你得避免使用這個(gè)方法去隱藏任何可以獲得焦點(diǎn)的元素哩牍,因?yàn)槿绻敲醋觯?dāng)用戶(hù)讓那個(gè)元素獲得焦點(diǎn)時(shí)令漂,會(huì)導(dǎo)致一個(gè)不可預(yù)料的焦點(diǎn)切換膝昆。這個(gè)方法在創(chuàng)建自定義復(fù)選框和單選按鈕時(shí)經(jīng)常被使用。

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);
}

雖然我們的元素自身不再顯示,它也依然占據(jù)本該占據(jù)的矩形大小患膛,它周?chē)脑氐男袨榫腿缤梢?jiàn)時(shí)一樣摊阀。記住用戶(hù)交互例如鼠標(biāo)懸停或者點(diǎn)擊在剪裁區(qū)域之外也不可能生效踪蹬。在我們的例子里胞此,剪裁區(qū)大小為零,這意味著用戶(hù)將不能與隱藏的元素直接交互跃捣。此外漱牵,這個(gè)屬性能夠使用各種過(guò)渡動(dòng)畫(huà)來(lái)實(shí)現(xiàn)不同的效果。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末疚漆,一起剝皮案震驚了整個(gè)濱河市酣胀,隨后出現(xiàn)的幾起案子刁赦,更是在濱河造成了極大的恐慌,老刑警劉巖闻镶,帶你破解...
    沈念sama閱讀 218,451評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件甚脉,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡铆农,警方通過(guò)查閱死者的電腦和手機(jī)牺氨,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,172評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)墩剖,“玉大人猴凹,你說(shuō)我怎么就攤上這事×朐恚” “怎么了郊霎?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,782評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)蒲障。 經(jīng)常有香客問(wèn)我歹篓,道長(zhǎng)瘫证,這世上最難降的妖魔是什么揉阎? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,709評(píng)論 1 294
  • 正文 為了忘掉前任,我火速辦了婚禮背捌,結(jié)果婚禮上毙籽,老公的妹妹穿的比我還像新娘。我一直安慰自己毡庆,他們只是感情好坑赡,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,733評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著么抗,像睡著了一般毅否。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上蝇刀,一...
    開(kāi)封第一講書(shū)人閱讀 51,578評(píng)論 1 305
  • 那天螟加,我揣著相機(jī)與錄音,去河邊找鬼吞琐。 笑死捆探,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的站粟。 我是一名探鬼主播黍图,決...
    沈念sama閱讀 40,320評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼奴烙!你這毒婦竟也來(lái)了助被?” 一聲冷哼從身側(cè)響起剖张,我...
    開(kāi)封第一講書(shū)人閱讀 39,241評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎揩环,沒(méi)想到半個(gè)月后修械,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,686評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡检盼,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,878評(píng)論 3 336
  • 正文 我和宋清朗相戀三年肯污,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片吨枉。...
    茶點(diǎn)故事閱讀 39,992評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡蹦渣,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出貌亭,到底是詐尸還是另有隱情柬唯,我是刑警寧澤,帶...
    沈念sama閱讀 35,715評(píng)論 5 346
  • 正文 年R本政府宣布圃庭,位于F島的核電站锄奢,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏剧腻。R本人自食惡果不足惜拘央,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,336評(píng)論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望书在。 院中可真熱鬧灰伟,春花似錦、人聲如沸儒旬。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,912評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)栈源。三九已至挡爵,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間甚垦,已是汗流浹背茶鹃。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,040評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留制轰,地道東北人前计。 一個(gè)月前我還...
    沈念sama閱讀 48,173評(píng)論 3 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像垃杖,于是被迫代替她去往敵國(guó)和親男杈。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,947評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容