1. 程式人生 > >CSS隱藏頁面元素的方法

CSS隱藏頁面元素的方法

none spa 交互操作 響應 pan 視覺 blog 如果 使用外部

Opacity

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

.hide {
  opacity: 0;
} 

Visibility

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

.hide {
   visibility: hidden;
}

display

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

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

.hide {
   display: none;
} 

position

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

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

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

clip-path

隱藏元素的另一種方法是通過剪裁它們來實現。這可以通過 clip 屬性來實現,但是這個屬性被廢棄了,換成一個更好的屬性叫做 clip-path

記住,clip-path 屬性還沒有被IE或Edge完全支持。如果要在你的 clip-path

中使用外部的 SVG 文件,瀏覽器支持度還要更低。使用 clip-path 屬性來隱藏元素的代碼看起來如下:

.hide {
  clip-path: polygon(0px 0px,0px 0px,0px 0px,0px 0px);
}

CSS隱藏頁面元素的方法