用 CSS 隱藏頁面元素

2022-03-06 05:03:20 字數 2563 閱讀 1382

用 css 隱藏頁面元素有許多種方法。你可以將

opacity 設為 0 

將 visibility 設為 hidden 

將 display 設為 none

將 position 設為 absolute 然後將位置設到不可見區域。

opacity,佔據網頁布局,可以互動,讀屏軟體可以讀到它

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

.hide

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

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

visibility,佔據網頁布局,不可以互動 ,讀屏軟體是讀不到的

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

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

.hide

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

而在 標籤裡面的 標籤則依然可以捕獲所有的滑鼠事件。一旦你的滑鼠移動到文字上, 本身變得可見並且事件註冊也隨之生效。

display,不佔據頁面布局,不可以互動,讀屏軟體也讀不到

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

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

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

.hide

在前乙個例子裡,將任何子孫元素 visibility 顯式設定成 visible 可以讓它變得可見,但是 display 不吃這一套,不管自身的 display 值是什麼,只要祖先元素的 display 是 none ,它們就都不可見。

position,移出布局,可以互動,隱藏的元素可以被讀屏軟體讀到

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

.hide

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

你得避免使用這個方法去隱藏任何可以獲得焦點的元素,因為如果那麼做,當使用者讓那個元素獲得焦點時,會導致乙個不可預料的焦點切換。這個方法在建立自定義核取方塊和單選按鈕時經常被使用。

隱藏元素的另一種方法是通過剪裁它們來實現。在以前,這可以通過 clip 屬性來實現,但是這個屬性被廢棄了,換成乙個更好的屬性叫做 clip-path 。nitish kumar 最近在 sitepoint 發表了 「介紹 clicp-path 屬性」 這篇文章,通過閱讀它可以了解這個屬性的更多高階用法。

記住, clip-path 屬性還 沒有在 ie 或者 edge 下被完全支援 。如果要在你的 clip-path 中使用外部的 svg 檔案,瀏覽器支援度還要更低。使用 clip-path 屬性來隱藏元素的**看起來如下:

.hide

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

css隱藏頁面元素的方法

用css隱藏頁面元素有許多種方法。第一種方法 opacity 0 opacity屬性通常用於設定乙個元素的透明度,從另乙個角度來看,如果透明度為0,也就從視覺上隱藏了該元素。這個屬性不是為改變元素的邊界框 bounding box 而設計的,元素本身依然佔據它自己的位置並對網頁的布局起作用,它也將響...

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

opacity屬性的意思是設定乙個元素的透明度。它不是為改變元素的邊界框 bounding box 而設計的。這意味著將 opacity 設為 0 只能從視覺上隱藏元素。而元素本身依然佔據它自己的位置並對網頁的布局起作用。它也將響應使用者互動。hide第二個要說的屬性是visibility。將它的值...

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

用 css 隱藏頁面元素的 5 種方法 opacity opacity 屬性的意思是設定乙個元素的透明度。這意味著將 opacity 設為 0 只能從視覺上隱藏元素,而元素本身依然佔據它自己的位置並對網頁的布局起作用,同時它將響應使用者互動。此外,元素在讀屏軟體中不會被隱藏。visibility 將...