用 CSS 隱藏頁面元素的 5 種方法
用 CSS 隱藏頁面元素有許多種方法。你可以將 opacity 設為 0、將 visibility 設為 hidden、將 display 設為 none 或者將 position 設為 absolute 然後將位置設到不可見區域。
你有沒有想過,為什麼我們要有這麼多技術來隱藏元素,而它們看起來都實現的是同樣的效果?每一種方法實際上與其他方法之間都有一些細微的不同,這些不同決定了在一個特定的場合下使用哪一個方法。這篇教程將覆蓋到那些你需要記住的細小不同點,讓你根據不同情況選擇上面這些方法中適合的方法來隱藏元素。
Opacity
opacity 屬性的意思是設定一個元素的透明度。它不是為改變元素的邊界框(bounding box)而設計的。這意味著將 opacity 設為 0 只能從視覺上隱藏元素。而元素本身依然佔據它自己的位置並對網頁的佈局起作用。它也將響應使用者互動。
.hide { opacity: 0; }
如果你打算使用 opacity 屬性在讀屏軟體中隱藏元素,很不幸,你並不能如願。元素和它所有的內容會被讀屏軟體閱讀,就像網頁上的其他元素那樣。換句話說,元素的行為就和它們不透明時一致。
我還要提醒一句,opacity 屬性可以用來實現一些效果很棒的動畫。任何 opacity 屬性值小於 1 的元素也會建立一個新的堆疊上下文(stacking context)。
看下面的例子:
看 @SitePoint 提供的例子“用 opacity 隱藏元素”
http://codepen.io/SitePoint/pen/bedZrR/
當你的滑鼠移到被隱藏的第 2 個的區塊上,元素狀態平滑地從完全透明過渡到完全不透明。區塊也將 cursor 屬性設定為了 pointer,這說明了使用者可以與它互動。
Visibility
第二個要說的屬性是 visibility。將它的值設為 hidden 將隱藏我們的元素。如同 opacity 屬性,被隱藏的元素依然會對我們的網頁佈局起作用。與 opacity 唯一不同的是它不會響應任何使用者互動。此外,元素在讀屏軟體中也會被隱藏。
這個屬性也能夠實現動畫效果,只要它的初始和結束狀態不一樣。這確保了 visibility 狀態切換之間的過渡動畫可以是時間平滑的(事實上可以用這一點來用 hidden 實現元素的延遲顯示和隱藏——譯者注)。
.hide { visibility: hidden; }
下面的例子演示了 visibility 與 opacity 有怎樣的不同:
看 @SitePoint 提供的例子“用 visibility 隱藏元素”
http://codepen.io/SitePoint/pen/pbJYpV/
注意,如果一個元素的 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; }
看下面的例子:
@SitePoint 提供的例子“用 display 隱藏元素”
http://codepen.io/SitePoint/pen/zBGbjb/
你將看到第二個塊元素內有一個 <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; }
下面的例子闡明瞭怎樣通過絕對定位的方式隱藏元素,並讓它和前面的那個例子效果一樣:
看 @SitePoint 提供的例子“用 position 屬性隱藏元素”
http://codepen.io/SitePoint/pen/QEboZm/
這種方法的主要原理是通過將元素的 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); }
下面是一個實際使用它的例子:
看 @SitePoint 提供的例子“用 clip-path 屬性隱藏元素”
http://codepen.io/SitePoint/pen/YWXgdW/
如果你把滑鼠懸停在第一個元素上,它依然可以影響第二個元素,儘管第二個元素已經通過 clip-path 隱藏了。如果你點選它,它會移除用來隱藏的 class,讓我們的元素從那個位置顯現出來。被隱藏元素中的文字仍然能夠通過讀屏軟體讀取,許多 WordPress 站點使用 clip-path 或者之前的 clip 來實現專門為讀屏軟體提供的文字。
雖然我們的元素自身不再顯示,它也依然佔據本該佔據的矩形大小,它周圍的元素的行為就如同它可見時一樣。記住使用者互動例如滑鼠懸停或者點選在剪裁區域之外也不可能生效。在我們的例子裡,剪裁區大小為零,這意味著使用者將不能與隱藏的元素直接互動。此外,這個屬效能夠使用各種過渡動畫來實現不同的效果。
結論
在這篇教程裡,我們看了 5 種不同的通過 CSS 隱藏元素的方法。每一種方法都與其他幾種有一點區別。知道你想要實現什麼有助於你決定採用哪一個屬性,隨著時間推移,你就能根據實際需求本能地選擇最佳方式了。如果你對於隱藏元素的這些方法還有任何問題,請在評論中留言。
原文:https://www.sitepoint.com/five-ways-to-hide-elements-in-css/
相關文章
- CSS 隱藏元素的八種方法CSS
- CSS隱藏元素方法CSS
- CSS“隱藏”元素的幾種方法的對比CSS
- 使用CSS隱藏HTML元素的4種常用方法CSSHTML
- 有趣的css—隱藏元素的7種思路CSS
- 隱藏元素兩種方式
- css如何隱藏一個元素CSS
- jQuery點選頁面其他地方隱藏顯示的元素jQuery
- 三種隱藏 HTML 元素的方式HTML
- 使用CSS隱藏元素滾動條CSS
- jQuery點選頁面其他地方隱藏指定元素詳解jQuery
- jQuery幾種隱藏span的方法jQuery
- 隱藏IP地址的三種方法
- 【CSS】CSS 世界 — 元素的顯示與隱藏學習總結CSS
- CSS 小結筆記之元素的隱藏與顯示CSS筆記
- css li元素中的文字超出隱藏不換行效果CSS
- 隱藏元素,保留功能
- CSS應用給網頁元素的幾種方式總結CSS網頁
- 用CSS製作隱藏選單CSS
- 小程式tabBar跳轉頁面並隱藏tabBartabBar
- 網頁元素居中的n種方法網頁
- robotframework 使用jQuery處理頁面display隱藏內容FrameworkjQuery
- absolute定位css元素居中的兩種方法CSS
- 使用CSS完成元素居中的七種方法CSS
- 用CSS建立列印頁面CSS
- 3種方法實現CSS隱藏滾動條並可以滾動內容CSS
- 點選頁面其它地方隱藏div所想到的jQuery的delegatejQuery
- 使用CSS定義頁面元素的外觀樣式CSS
- jQuery隱藏一個div元素jQuery
- jQuery 判斷元素是否隱藏jQuery
- 發現ThinkPHP裡面隱藏了幾個有用的方法PHP
- css隱藏滾動條CSS
- CSS圍住浮動元素的三種方法CSS
- 使用 jQuery 選擇器獲取頁面元素,然後利用 jQuery 物件的 css() 方法設定其 display 樣式屬性,從而實現顯示和隱藏效果。jQuery物件CSS
- tp5 Nginx隱藏index.php的配置方法NginxIndexPHP
- js獲取頁面dom元素的幾種常用方式JS
- selenium 常見方法和頁面元素的操作
- .NET 5 中的隱藏特性