亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > CSS > 正文

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

2024-07-11 08:57:28
字體:
來源:轉載
供稿:網友

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

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

Opacity

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

.hide {
  opacity: 0;
}

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

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

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

Visibility

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

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

.hide {
   visibility: hidden;
}

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

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

Display

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

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

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

.hide {
   display: none;
}

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

現在,將鼠標移到第一個塊元素上面幾次,然后點擊它。這個操作將讓第二個塊元素顯現出來,它其中的數字將是一個大于 0 的數。這是因為,元素即使被這樣設置成對用戶隱藏,還是可以通過 JavaScript 來進行操作。

Position

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

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

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

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

Clip-path

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

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

雖然我們的元素自身不再顯示,它也依然占據本該占據的矩形大小,它周圍的元素的行為就如同它可見時一樣。記住用戶交互例如鼠標懸?;蛘唿c擊在剪裁區域之外也不可能生效。在我們的例子里,剪裁區大小為零,這意味著用戶將不能與隱藏的元素直接交互。此外,這個屬性能夠使用各種過渡動畫來實現不同的效果。

結論

在這篇教程里,我們看了 5 種不同的通過 CSS 隱藏元素的方法。每一種方法都與其他幾種有一點區別。知道你想要實現什么有助于你決定采用哪一個屬性,隨著時間推移,你就能根據實際需求本能地選擇最佳方式了。

本文轉載自:眾成翻譯
譯者:十年蹤跡
鏈接:http://www.zcfy.cc/article/457
原文:https://www.sitepoint.com/five-ways-to-hide-elements-in-css/

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产香蕉精品视频一区二区三区| 亚洲精选一区二区| 欧美激情小视频| 欧美精品一区在线播放| 欧美精品福利视频| 亚洲精品之草原avav久久| 久久国产精品99国产精| 日韩在线高清视频| 亚洲热线99精品视频| 日韩亚洲第一页| 日韩大胆人体377p| 欧美激情一区二区三区高清视频| 欧美大尺度激情区在线播放| 久久深夜福利免费观看| 精品亚洲国产成av人片传媒| 亚洲精品按摩视频| 国产成人精品在线| 最新国产成人av网站网址麻豆| 国产亚洲成av人片在线观看桃| 亚洲人成毛片在线播放| 久久免费国产视频| 中文字幕免费精品一区| 啊v视频在线一区二区三区| 欧美黑人狂野猛交老妇| 亚洲a区在线视频| 精品久久久精品| 欧美精品激情在线观看| 国产玖玖精品视频| 亚洲成人av片在线观看| 欧美老肥婆性猛交视频| 黄色精品在线看| 正在播放欧美一区| 欧美剧在线观看| 国产福利视频一区| 国产欧美中文字幕| 精品久久久久久久久中文字幕| 欧美视频中文在线看| 色偷偷88888欧美精品久久久| 亚洲精品免费网站| 国产精品你懂得| 日韩av在线网址| 久久天天躁夜夜躁狠狠躁2022| 九九九久久久久久| 精品呦交小u女在线| 亚洲国产精品美女| 亚洲尤物视频网| 久久高清视频免费| 亚洲第一福利视频| 久久久久久一区二区三区| 日韩一区二区在线视频| 精品偷拍一区二区三区在线看| 国产精品情侣自拍| 欧美性xxxx极品hd满灌| 亚洲一区二区精品| 中文字幕在线成人| 97欧美精品一区二区三区| 亚洲精品福利资源站| 欧美大片在线看免费观看| 中文字幕在线精品| 亚洲美女av电影| 欧美精品制服第一页| 欧美日韩国产精品| 这里只有精品在线观看| 97国产精品久久| 欧美—级高清免费播放| 欧美成年人视频| 狠狠色狠狠色综合日日小说| 国产精品激情自拍| 欧美大片va欧美在线播放| 久久精彩免费视频| 亚洲大胆人体在线| 欧日韩在线观看| 亚洲精品国产精品国自产在线| 国产日韩欧美电影在线观看| 久久久午夜视频| 中日韩美女免费视频网址在线观看| 欧美麻豆久久久久久中文| 亚洲成人1234| 久久久久国产精品免费网站| 狠狠躁天天躁日日躁欧美| 91欧美日韩一区| 韩国美女主播一区| 国产欧美日韩精品在线观看| 欧美日韩一区二区精品| 九九热这里只有精品6| 深夜福利一区二区| 日韩免费观看在线观看| 日韩精品久久久久| 久久99视频精品| 久热国产精品视频| 午夜欧美不卡精品aaaaa| 最近2019中文字幕第三页视频| 久久精品久久久久久| 欧美性猛交xxxxx水多| 在线精品国产成人综合| 国产亚洲免费的视频看| 一区二区三区亚洲| 亚洲欧美一区二区三区久久| 欧美日本中文字幕| 亚洲区在线播放| 久久久久免费精品国产| 日本国产精品视频| 久久成人一区二区| 亚洲欧美日韩在线一区| 日韩中文字幕第一页| 91在线色戒在线| 日韩中文视频免费在线观看| 另类天堂视频在线观看| 在线亚洲男人天堂| 精品高清一区二区三区| 富二代精品短视频| 久久香蕉国产线看观看av| 亚洲开心激情网| 欧美孕妇性xx| 国产精品91一区| 色樱桃影院亚洲精品影院| 亚洲一区二区三区视频播放| 国产成人+综合亚洲+天堂| 国产成人小视频在线观看| 91精品国产91| 欧美日本中文字幕| 国产视频精品久久久| 在线电影欧美日韩一区二区私密| 91欧美激情另类亚洲| www.久久草.com| 亚洲成成品网站| 欧美日本高清视频| 国产成人精品999| 成人xxxx视频| 国产欧美日韩精品专区| 亚洲天堂免费在线| 国产亚洲福利一区| 91精品久久久久久久久中文字幕| 日韩大陆欧美高清视频区| 亚洲xxx自由成熟| 国产日韩综合一区二区性色av| 久久免费成人精品视频| 久久精品中文字幕| 欧美黄色小视频| 国产99在线|中文| 亚洲色图狂野欧美| 亚洲xxxxx电影| 久热精品视频在线免费观看| 国产精品久久久久久久久久久久久| 久久手机免费视频| 日韩在线中文字| 欧美电影电视剧在线观看| 国产精品av在线| 日韩免费不卡av| 欧美美女操人视频| 亚洲精品自产拍| 国产精品美乳一区二区免费| 国产精品视频午夜| 欧美日韩亚洲激情| 国产精品第3页| 性金发美女69hd大尺寸| 国产免费一区二区三区香蕉精| 欧美又大又硬又粗bbbbb| 亚洲欧美在线看| 欧美在线视频a| 欧美洲成人男女午夜视频| 欧美插天视频在线播放| 成人国产精品一区| 久久躁狠狠躁夜夜爽|