更新時間:2021-04-01 17:23:50 來源:動力節(jié)點 瀏覽1153次
在HTML頁面開發(fā)中使用CSS隱藏元素有許多種方法,你可以將 opacity 設(shè)為 0、將 visibility 設(shè)為 hidden、將 display 設(shè)為 none 或者將 position 設(shè)為 absolute 然后將位置設(shè)到不可見區(qū)域。下面我們就來詳細(xì)介紹CSS隱藏元素的5種方法。
opacity 屬性的意思是設(shè)置一個元素的透明度。它不是為改變元素的邊界框(bounding box)而設(shè)計的。這意味著將 opacity 設(shè)為 0 只能從視覺上隱藏元素。而元素本身依然占據(jù)它自己的位置并對網(wǎng)頁的布局起作用。它也將響應(yīng)用戶交互。
.hide {
opacity: 0;}
如果你打算使用 opacity 屬性在讀屏軟件中隱藏元素,很不幸,你并不能如愿。元素和它所有的內(nèi)容會被讀屏軟件閱讀,就像網(wǎng)頁上的其他元素那樣。換句話說,元素的行為就和它們不透明時一致。
第二個要說的屬性是 visibility。將它的值設(shè)為 hidden 將隱藏我們的元素。如同 opacity 屬性,被隱藏的元素依然會對我們的網(wǎng)頁布局起作用。與 opacity 唯一不同的是它不會響應(yīng)任何用戶交互。此外,元素在讀屏軟件中也會被隱藏。
這個屬性也能夠?qū)崿F(xiàn)動畫效果,只要它的初始和結(jié)束狀態(tài)不一樣。這確保了 visibility 狀態(tài)切換之間的過渡動畫可以是時間平滑的(事實上可以用這一點來用 hidden 實現(xiàn)元素的延遲顯示和隱藏——譯者注)。
.hide {
?visibility: hidden;}
display 屬性依照詞義真正隱藏元素。將 display 屬性設(shè)為 none 確保元素不可見并且連盒模型也不生成。使用這個屬性,被隱藏的元素不占據(jù)任何空間。不僅如此,一旦 display 設(shè)為 none 任何對該元素直接打用戶交互操作都不可能生效。此外,讀屏軟件也不會讀到元素的內(nèi)容。這種方式產(chǎn)生的效果就像元素完全不存在。
任何這個元素的子孫元素也會被同時隱藏。為這個屬性添加過渡動畫是無效的,它的任何不同狀態(tài)值之間的切換總是會立即生效。
不過請注意,通過 DOM 依然可以訪問到這個元素。因此你可以通過 DOM 來操作它,就像操作其他的元素。
.hide {
?display: none;}
假設(shè)有一個元素你想要與它交互,但是你又不想讓它影響你的網(wǎng)頁布局,沒有合適的屬性可以處理這種情況(opacity 和 visibility 影響布局, display 不影響布局但又無法直接交互——譯者注)。在這種情況下,你只能考慮將元素移出可視區(qū)域。這個辦法既不會影響布局,有能讓元素保持可以操作。下面是采用這 種辦法的 CSS:
.hide {
?position: absolute;
?top: -9999px;
?left: -9999px;}
隱藏元素的另一種方法是通過剪裁它們來實現(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);}
本文我們介紹了 5 種不同的通過 CSS 隱藏元素的方法。每一種方法實際上與其他方法之間都有一些細(xì)微的不同,這些不同決定了在一個特定的場合下使用哪一個方法。我們可以結(jié)合本站的CSS教程中覆蓋到的那些你需要記住的細(xì)小不同點,讓你根據(jù)不同情況選擇上面這些方法中適合的方法來隱藏元素。
初級 202925
初級 203221
初級 202629
初級 203743