整合營銷服務商

          電腦端+手機端+微信端=數(shù)據(jù)同步管理

          免費咨詢熱線:

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

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

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

          opacity

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

          .hide {
           opacity: 0;}

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

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

          看下面的例子:

          看 @SitePoint 提供的例子“用 opacity 隱藏元素”

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

          我自己是一名從事了多年開發(fā)的web前端老程序員,目前辭職在做自己的web前端私人定制課程,今年年初我花了一個月整理了一份最適合2019年學習的web前端學習干貨,各種框架都有整理,送給每一位前端小伙伴,想要獲取的可以關(guān)注我的頭條號并在后臺私信我:前端,即可免費獲取。

          visibility

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

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

          .hide {
           visibility: hidden;}

          下面的例子演示了 visibility 與 opacity 有怎樣的不同:

          看 @SitePoint 提供的例子“用 visibility 隱藏元素”

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

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

          display

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

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

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

          .hide {
           display: none;}

          看下面的例子:

          @SitePoint 提供的例子“用 display 隱藏元素”

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

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

          position

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

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

          下面的例子闡明了怎樣通過絕對定位的方式隱藏元素,并讓它和前面的那個例子效果一樣:

          看 @SitePoint 提供的例子“用 position 屬性隱藏元素”

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

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

          clip-path

          隱藏元素的另一種方法是通過剪裁它們來實現(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);}

          下面是一個實際使用它的例子:

          看 @SitePoint 提供的例子“用 clip-path 屬性隱藏元素”

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

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

          結(jié)論

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

          有沒有想過,為什么我們要有這么多技術(shù)來隱藏元素,而它們看起來都實現(xiàn)的是同樣的效果?每一種方法實際上與其他方法之間都有一些細微的不同,這些不同決定了在一個特定的場合下使用哪一個方法。今天就帶大家了解一下不同的方法分別用于那種場合更合適,下面就讓我們一起來看一看吧!

          一、opacity

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

          .hide {
          opacity: 0;}
          

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

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

          看下面的例子:

          看 @SitePoint 提供的例子“用 opacity 隱藏元素”

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

          二、visibility

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

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

          .hide {
          visibility: hidden;}
          

          下面的例子演示了 visibility 與 opacity 有怎樣的不同:

          看 @SitePoint 提供的例子“用 visibility 隱藏元素”

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

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

          三、display

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

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

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

          .hide {
          display: none;}
          

          看下面的例子:

          @SitePoint 提供的例子“用 display 隱藏元素”

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

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

          四、position

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

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

          下面的例子闡明了怎樣通過絕對定位的方式隱藏元素,并讓它和前面的那個例子效果一樣:

          看 @SitePoint 提供的例子“用 position 屬性隱藏元素”

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

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

          五、clip-path

          隱藏元素的另一種方法是通過剪裁它們來實現(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);}
          

          下面是一個實際使用它的例子:

          看 @SitePoint 提供的例子“用 clip-path 屬性隱藏元素”

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

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

          這五種CSS隱藏元素方法每一種用到的情況都不同,需要大家根據(jù)實際情況去判斷,隨著練習實戰(zhàn)的增多,相信大家對CSS隱藏元素就能做到得心應手了。也可以加入465042726,一起討論關(guān)于web前端方面的問題。

          點圖主要是指網(wǎng)頁焦點位置的圖片,一般焦點圖可以是單張圖,也可以是一組動態(tài)切換的圖片的組合。由于處在終端用戶視覺焦點位置因此焦點圖的作用至關(guān)重要,焦點圖也成為網(wǎng)站首頁面設計的重點。焦點圖樣式如下所示:

          焦點輪播圖示例

          常用實現(xiàn)焦點圖或者輪播圖的前端技術(shù)較多,如JavaScript技術(shù)、BootStrap組件、CSS技術(shù)等。本文主要介紹使用CSS3提供的動畫功能實現(xiàn)簡單輪播效果。首先給出輪播實現(xiàn)動畫效果如下所示:

          焦點圖實現(xiàn)效果展示


          1、實現(xiàn)的基本思路

          本例題設計實現(xiàn)圖文輪播,主要包括圖片的輪播與文字輪播兩部分,基本思路是實現(xiàn)按照周期改變圖層背景實現(xiàn)圖片的輪播。改變或者移動文字圖層位置實現(xiàn)文字部分的移動及動畫效果。

          2、animation與@keyframe

          通過使用CSS3提供的animation屬性方法,我們可以編寫動畫,實現(xiàn)元素的移動、放縮、顏色改變等動畫效果。Animation主要屬性包括綁定動畫的名稱、執(zhí)行動畫的實踐、動畫啊延遲等相關(guān)屬性。基本語法如下:

          對應屬性值分別為動畫名稱、執(zhí)行時間、速度曲線、延遲時間、執(zhí)行次數(shù)、是否反向播放;

          @keyframes與animation結(jié)合使用,主要用于實現(xiàn)對動畫進行定義。通過定義動畫時長的百分比,確定在各個階段動畫的效果。@keyframes定義形式如下:

          @keyframe animation_name{
          	0%{樣式1}
          	100%{樣式2}
          }
          

          3、transform:translateX

          該屬性主要用于實現(xiàn)x軸方向元素的移動,需要在使用時提供參數(shù)值,參數(shù)即為移動的值,正負號表示移動的方向,如:

          transform:translateX(-1000px);
          

          4、改變背景background-image

          CSS屬性background-image主要用于設置元素的背景,常用于頁面、圖層的背景圖片的設置。代碼示例如下:

          background-image:url('images/1.jpg');
          

          CSS3動畫實現(xiàn)焦點圖效果實現(xiàn)

          本例主要實現(xiàn)圖文輪播效果,主要素材為輪播圖片,采用了1000*600的圖片5張,輪播周期為20s。圖片縮略圖如下:

          素材縮略圖

          頁面主要采用div為容器實現(xiàn)布局,其中輪播圖片所在層為父層,文字部分為子層,子層相對父層底部定位。根據(jù)圖片尺寸設置子層寬度為5000,超出部分隱藏。頁面布局代碼如下:

          整體頁面文件代碼

          頁面基本HTML代碼如上所示,a層為圖片展示層,s層為文字展示層,c類型的div為文字容器層。頁面效果如下所示:

          頁面布局效果

          動畫實現(xiàn)主要在style css樣式部分進行編寫,定義兩個動畫,名稱分別為mymove()與smove(),其中mymove主要用于實現(xiàn)圖片切換,綁定到父層a上。Smove主要用于實現(xiàn)文字移動,綁定到s子層上。動畫實現(xiàn)部分代碼描述如下:

          CSS動畫部分代碼

          動畫實現(xiàn)部分主要代碼如上所示,通過@keyframe分別對mymove與smove動畫進行規(guī)則編寫,最終實現(xiàn)圖文輪播的效果。本例頁面布局樣式部分代碼如下所示:

          元素樣式代碼


          本頭條號長期關(guān)注編程資訊分享;編程課程、素材、代碼分享及編程培訓。如果您對以上方面有興趣或代碼錯誤、建議與意見,可以聯(lián)系作者,共同探討。期待大家關(guān)注!相關(guān)文章鏈接如下:

          前端開發(fā)-JavaScript DOM動態(tài)生成文本框

          前端開發(fā)-拼圖游戲(N數(shù)碼問題)A*算法智能求解效果展示

          前端設計-JavaScript美女拼圖游戲開發(fā)實例

          前端設計-教你如何快速繪制HTML5動畫

          前端設計-響應式頁面開發(fā)基礎

          前端設計-Ajax技術(shù)及實例展示


          主站蜘蛛池模板: 亚洲综合av永久无码精品一区二区| 无码一区二区三区| 久久亚洲一区二区| 日韩精品无码一区二区三区| 国产高清在线精品一区二区 | 国模精品一区二区三区视频| 精品不卡一区二区| AV怡红院一区二区三区| 一色一伦一区二区三区| 国产一区二区三区日韩精品| 国产乱子伦一区二区三区| 国产成人欧美一区二区三区 | 亚洲一区二区三区夜色| 午夜视频久久久久一区| 美女免费视频一区二区| 国产精品一区二区久久不卡| 精品一区二区三区免费毛片爱| 免费人妻精品一区二区三区| 国内精品视频一区二区三区八戒| 国产一区二区三精品久久久无广告| 亚洲中文字幕一区精品自拍| 国产精品福利一区二区| 中文字幕在线无码一区二区三区| 国产一区三区二区中文在线| 日韩精品一区二区三区在线观看l 日韩精品一区二区三区毛片 | 夜夜精品无码一区二区三区| 国产福利微拍精品一区二区 | 熟女少妇丰满一区二区| 国产免费私拍一区二区三区| 国模吧无码一区二区三区| 久久精品一区二区三区资源网| 99国产精品一区二区| 精品一区二区三区免费 | 亚洲国产福利精品一区二区| 亚洲AⅤ无码一区二区三区在线 | 亚洲中文字幕久久久一区| 国产在线精品一区在线观看| 精品国产日产一区二区三区| 人妻夜夜爽天天爽爽一区| 日本一区午夜爱爱| 亚洲码欧美码一区二区三区|