Warning: error_log(/data/www/wwwroot/hmttv.cn/caches/error_log.php): failed to open stream: Permission denied in /data/www/wwwroot/hmttv.cn/phpcms/libs/functions/global.func.php on line 537 Warning: error_log(/data/www/wwwroot/hmttv.cn/caches/error_log.php): failed to open stream: Permission denied in /data/www/wwwroot/hmttv.cn/phpcms/libs/functions/global.func.php on line 537 一级做a爰黑人又硬又粗视,九一国产精品视频,精品国产国产综合精品

          整合營(yíng)銷服務(wù)商

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

          免費(fèi)咨詢熱線:

          5 種用 CSS 隱藏頁(yè)面元素的方法

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

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

          opacity

          opacity 屬性的意思是設(shè)置一個(gè)元素的透明度。它不是為改變?cè)氐倪吔缈颍╞ounding box)而設(shè)計(jì)的。這意味著將 opacity 設(shè)為 0 只能從視覺上隱藏元素。而元素本身依然占據(jù)它自己的位置并對(duì)網(wǎng)頁(yè)的布局起作用。它也將響應(yīng)用戶交互。

          .hide {
           opacity: 0;}

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

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

          看下面的例子:

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

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

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

          visibility

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

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

          .hide {
           visibility: hidden;}

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

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

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

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

          display

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

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

          不過請(qǐng)注意,通過 DOM 依然可以訪問到這個(gè)元素。因此你可以通過 DOM 來(lái)操作它,就像操作其他的元素。

          .hide {
           display: none;}

          看下面的例子:

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

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

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

          position

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

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

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

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

          這種方法的主要原理是通過將元素的 top 和 left 設(shè)置成足夠大的負(fù)數(shù),使它在屏幕上不可見。采用這個(gè)技術(shù)的一個(gè)好處(或者潛在的缺點(diǎn))是用它隱藏的元素的內(nèi)容可以被讀屏軟件讀取。這完全可以理解,是因?yàn)槟阒皇菍⒃匾频娇梢晠^(qū)域外面讓用戶無(wú)法看到它。

          你得避免使用這個(gè)方法去隱藏任何可以獲得焦點(diǎn)的元素,因?yàn)槿绻敲醋?,?dāng)用戶讓那個(gè)元素獲得焦點(diǎn)時(shí),會(huì)導(dǎo)致一個(gè)不可預(yù)料的焦點(diǎn)切換。這個(gè)方法在創(chuàng)建 自定義復(fù)選框和單選按鈕時(shí)經(jīng)常被使用。(用 DOM 模擬復(fù)選框和單選按鈕,但用這個(gè)方法隱藏真正的 checkbox 和 radio 元素來(lái)“接收”焦點(diǎn)切換——譯者注)

          clip-path

          隱藏元素的另一種方法是通過剪裁它們來(lái)實(shí)現(xiàn)。在以前,這可以通過 clip 屬性來(lái)實(shí)現(xiàn),但是這個(gè)屬性被廢棄了,換成一個(gè)更好的屬性叫做 clip-path。Nitish Kumar 最近在 SitePoint 發(fā)表了“介紹 clicp-path 屬性”這篇文章,通過閱讀它可以了解這個(gè)屬性的更多高級(jí)用法。

          記住,clip-path 屬性還沒有在 IE 或者 Edge 下被完全支持。如果要在你的 clip-path 中使用外部的 SVG 文件,瀏覽器支持度還要更低。使用 clip-path 屬性來(lái)隱藏元素的代碼看起來(lái)如下:

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

          下面是一個(gè)實(shí)際使用它的例子:

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

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

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

          結(jié)論

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

          擊右上方紅色按鈕關(guān)注“小鄭搞碼事”,每天都能學(xué)到知識(shí),搞懂一個(gè)問題!

          隱藏一個(gè)元素的方法有很多,比如剪裁,定位到屏幕外,明度變化等都可以。雖然都是肉眼不可見,但背后卻在多個(gè)維度上都有差別。

          下面說(shuō)一下script:

          如果希望元素不可見,同時(shí)不占據(jù)空間,輔助設(shè)備無(wú)法訪問,同時(shí)不渲染,可以使用script標(biāo)簽隱藏。例如:

          此時(shí),圖片1.jpg是不會(huì)有請(qǐng)求的script標(biāo)簽是不支持嵌套的,因此,如果希望在script標(biāo)簽中再放置其他不渲染的模板內(nèi)容,可以試試使用textarea元素,例如:

          圖片2.jpg也是不會(huì)有請(qǐng)求的。

          另外,script標(biāo)簽隱藏內(nèi)容獲取使用script.innerHTML,textarea使用textarea.value。

          為一個(gè)優(yōu)秀的前端,我們經(jīng)常遇到需要隱藏網(wǎng)頁(yè)上的元素的情況。在本文中,我們將分享8 種在 CSS 中隱藏元素的方法,每種方法都有優(yōu)點(diǎn)和注意事項(xiàng)。

          Opacity and Filter:Opacity

          隱藏元素最簡(jiǎn)單的方法之一是調(diào)整其不透明度。opacity 屬性允許我們通過將其值設(shè)置為 0 來(lái)使元素完全透明。例如:

          .element {
            opacity: 0;
          }
          

          或者,我們可以將過濾器屬性與 opacity() 函數(shù)一起使用:

          .element {
            filter: opacity(0);
          }
          

          opacity 和 filter: opacity() 都可以設(shè)置動(dòng)畫并提供良好的性能。但是,需要注意的是,即使完全透明,元素仍保留在頁(yè)面上并且仍然可以觸發(fā)事件。

          Visibility

          Visibility屬性允許我們控制元素的可見性。通過將其設(shè)置為隱藏,我們可以隱藏元素,同時(shí)保留它在布局中占用的空間。例如:

          .element {
            visibility: hidden;
          }
          

          默認(rèn)情況下,輔助技術(shù)仍然可以訪問隱藏元素的內(nèi)容,因此考慮對(duì)可訪問性的影響非常重要。要完全隱藏內(nèi)容,可能需要其他 CSS 屬性或 ARIA 屬性,例如 aria-hidden="true"。

          Display

          display 屬性是一種廣泛使用的隱藏元素的方法。通過將其設(shè)置為 none,我們可以有效地從文檔流中刪除該元素,使其就像在 DOM 中從未存在過一樣。例如:

          .element {
           display: none;
          }
          

          雖然 display: none 是一個(gè)流行的選擇,但它有一些局限性。它無(wú)法設(shè)置動(dòng)畫,并且應(yīng)用時(shí)會(huì)觸發(fā)布局更改,從而影響頁(yè)面上其他元素的位置。為了緩解這種情況,我們可以使用其他技術(shù),例如定位。

          Hidden 屬性

          在 HTML 中,我們有隱藏屬性,可以將其添加到任何元素以隱藏它。當(dāng)存在hidden屬性時(shí),瀏覽器應(yīng)用其默認(rèn)樣式,相當(dāng)于設(shè)置display:none。例如:

          <p hidden>Hidden content</p>
          

          當(dāng)標(biāo)簽的樣式不允許被改變時(shí),此屬性非常有用。但是,它與使用 display :none有相同的優(yōu)點(diǎn)和限制。

          使用 z-index

          z-index 屬性控制 z 軸上元素的堆疊順序。給覆蓋元素分配更高的z-index值,我們可以在視覺上隱藏其下方的元素。例如:

          .element {
            position: relative;
            z-index: 1;
          }
          


          .overlay {
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            background-color: #ffffff; /* Same as the page background color */
            z-index: 2;
          }
          

          在此示例中,覆蓋元素位于使用較高 z-index 值的元素之上。

          Color AIpha Transparency

          我們還可以單獨(dú)隱藏特定的視覺屬性,例如顏色、背景顏色或邊框顏色,而不是使整個(gè)元素透明。這項(xiàng)技術(shù)使我們能夠創(chuàng)建有趣的效果和動(dòng)畫。我們可以通過將 alpha 通道設(shè)置為 0 的 rgba() 值來(lái)實(shí)現(xiàn)這一點(diǎn)。例如:

          .element {
            color: rgba(0, 0, 0, 0);
            background-color: rgba(0, 0, 0, 0);
            border-color: rgba(0, 0, 0, 0);
          }
          

          值得注意的是,這種技術(shù)可能不適用于具有圖像背景的元素,除非它們是使用線性漸變或類似方法生成的。

          CIip-Path

          Clip-path 屬性允許我們創(chuàng)建一個(gè)剪切區(qū)域來(lái)確定元素的哪些部分是可見的。通過設(shè)置一個(gè)值,例如circle(0),我們可以完全隱藏該元素。例如:

          .element {
            clip-path: circle(0);
          }
          

          使用剪輯路徑為有趣的動(dòng)畫提供了范圍。

          clip-path 屬性可以用于創(chuàng)建復(fù)雜的裁剪形狀,從而實(shí)現(xiàn)各種有趣的效果。在這種情況下,使用 circle(0) 作為裁剪路徑,是為了將元素完全裁剪掉,即不顯示任何內(nèi)容。

          需要注意的是,clip-path 是一個(gè)比較新的 CSS 屬性,不是所有瀏覽器都支持它。另外,即使瀏覽器支持 clip-path,也有可能出現(xiàn)一些兼容性問題,因此在使用 clip-path 時(shí)需要進(jìn)行充分的測(cè)試和兼容性處理。

          絕對(duì)定位

          位置屬性允許我們將元素從頁(yè)面布局中的默認(rèn)位置移動(dòng)。通過使用position:absolute,我們可以將元素重新定位到屏幕外,從而有效地將其隱藏。例如:

          .element {
            position: absolute;
            left: -9999px;
          }
          

          絕對(duì)定位提供了出色的瀏覽器支持,并且元素的原始尺寸保持不變。但是,需要注意的是,更改位置可能會(huì)影響頁(yè)面的整體布局。此外,屏幕外的元素可能無(wú)法交互,因?yàn)樗鼈儾辉傥挥谝暱趦?nèi)。

          結(jié)論

          總之,CSS 提供了多種技術(shù)來(lái)隱藏網(wǎng)頁(yè)上的元素。通過了解每種方法的優(yōu)點(diǎn)和局限性,我們可以為我們的特定用例選擇最合適的方法。


          主站蜘蛛池模板: 色婷婷AV一区二区三区浪潮| 一区二区免费国产在线观看| 久久亚洲国产精品一区二区| 国产精品久久亚洲一区二区 | 精品福利视频一区二区三区 | 亚洲AV色香蕉一区二区| 亚洲AV无码一区二区三区人| 亚洲爽爽一区二区三区| 男人的天堂精品国产一区| ...91久久精品一区二区三区| 国产福利一区二区三区在线视频 | 国产福利一区二区在线视频| 国产美女视频一区| 果冻传媒董小宛一区二区| 免费无码一区二区三区| 麻豆一区二区在我观看| 国产伦精品一区二区三区精品 | 日韩人妻精品无码一区二区三区| 久久综合精品不卡一区二区| 亚洲日韩AV一区二区三区四区| 精品国产一区二区麻豆| 国偷自产Av一区二区三区吞精| 无码精品人妻一区二区三区人妻斩 | 亚洲国产欧美一区二区三区| 久久精品国产第一区二区| 91一区二区三区四区五区| 日韩精品无码人妻一区二区三区 | 亚洲乱色熟女一区二区三区蜜臀| 国产一区二区在线观看视频| 亚洲无删减国产精品一区| 波多野结衣在线观看一区| 人妻天天爽夜夜爽一区二区| 欧洲精品码一区二区三区免费看 | 国产午夜毛片一区二区三区| 极品人妻少妇一区二区三区| 久久精品综合一区二区三区| 久久精品国内一区二区三区| 久久人妻内射无码一区三区| 一区二区日韩国产精品| 亚洲AV无码一区二区一二区| 久久精品一区二区免费看|