整合營銷服務商

          電腦端+手機端+微信端=數據同步管理

          免費咨詢熱線:

          廣州藍景技術分享—CSS中實現元素的隱藏方法

          ello~~各位小伙伴,今天我們廣州藍景實訓部,繼續和大家分享前端技術干貨,CSS隱藏元素

          總結出7種隱藏元素的辦法

          1.CSS display的值是none。(該元素是不會在頁面上顯示的)

          div{
              display: none;
          }


          2. type="hidden"的表單元素。(該元素是不會在頁面上顯示的)

          3. 寬度和高度都顯式設置為0。(該元素會在頁面上顯示)

          div{
              width: 0;
              height: 0;
          }

          4. 一個祖先元素是隱藏的,(該祖先以及祖先以下的元素是不會在頁面上顯示)

          5. CSS visibility的值是hidden(該元素是會在頁面上顯示,還占原來的位置)

          div{
              visibility: hidden;
          }

          6. CSS opacity的指數是0(該元素是會在頁面上顯示,還占原來的位置)

          div{
              opacity: 0;
          }

          7. 將position設為absolute然后將位置設到不可見區域

          div{
             position: absolute;
             top: -9999px;
             left: -9999px;
          }

          想要了解更多web前端開發技術資料,可在評論區留言!也可添加我們微信:philip_tan

          為一個優秀的前端,我們經常遇到需要隱藏網頁上的元素的情況。在本文中,我們將分享8 種在 CSS 中隱藏元素的方法,每種方法都有優點和注意事項。

          Opacity and Filter:Opacity

          隱藏元素最簡單的方法之一是調整其不透明度。opacity 屬性允許我們通過將其值設置為 0 來使元素完全透明。例如:

          .element {
            opacity: 0;
          }
          

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

          .element {
            filter: opacity(0);
          }
          

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

          Visibility

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

          .element {
            visibility: hidden;
          }
          

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

          Display

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

          .element {
           display: none;
          }
          

          雖然 display: none 是一個流行的選擇,但它有一些局限性。它無法設置動畫,并且應用時會觸發布局更改,從而影響頁面上其他元素的位置。為了緩解這種情況,我們可以使用其他技術,例如定位。

          Hidden 屬性

          在 HTML 中,我們有隱藏屬性,可以將其添加到任何元素以隱藏它。當存在hidden屬性時,瀏覽器應用其默認樣式,相當于設置display:none。例如:

          <p hidden>Hidden content</p>
          

          當標簽的樣式不允許被改變時,此屬性非常有用。但是,它與使用 display :none有相同的優點和限制。

          使用 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

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

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

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

          CIip-Path

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

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

          使用剪輯路徑為有趣的動畫提供了范圍。

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

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

          絕對定位

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

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

          絕對定位提供了出色的瀏覽器支持,并且元素的原始尺寸保持不變。但是,需要注意的是,更改位置可能會影響頁面的整體布局。此外,屏幕外的元素可能無法交互,因為它們不再位于視口內。

          結論

          總之,CSS 提供了多種技術來隱藏網頁上的元素。通過了解每種方法的優點和局限性,我們可以為我們的特定用例選擇最合適的方法。

          1)定義n初始值0,

          <script>
              Vue.config.productionTip = false
              const vm = new Vue({
                  el: "#app",
                  data: {
                      "n": 0
                  },
                  methods: {},
                  computed: {},
          
              })
          </script>

          (2)定義自加按鈕,展示n的值,和判斷結果

          <p><a class="btn btn-block btn-primary" @click="n++">自加</a></p>
          <h2>n == {{n}}</h2>
          <h3 v-text="n == 1"></h3>

          1、v-show

          <h1 style="color: red">使用v-show進行條件渲染</h1>
          <h3 v-show="n == 1">使用v-show進行條件渲染</h3>

          2、v-if

          <h1 style="color: red">使用v-if進行條件渲染</h1>
          <h3 v-if="n == 1">使用v-if進行條件渲染</h3>

          3、v-if v-else-if v-else

          <h1 style="color: red">使用if else-if else進行條件渲染 </h1>
          <h3 v-if="n === 1">使用v-if進行條件渲染 if else-if - v-if="n === 1"</h3>
          <h3 v-else-if="n == 2">使用v-if進行條件渲染 if else-if - v-else-if="n == 2"</h3>
          <h3 v-else-if="n == 3">使用v-if進行條件渲染 if else-if - v-else-if="n == 3"</h3>
          <h3 v-else>使用v-if進行條件渲染 if else-if - v-else</h3>

          4、template

          <h1 style="color: red">使用template v-if進行條件渲染 </h1>
          <template v-if="n == 1">
              <h3>使用v-if進行條件渲染 - template v-if="n == 1"</h3>
              <h3>使用v-if進行條件渲染 - template v-if="n == 1"</h3>
              <h3>使用v-if進行條件渲染 - template v-if="n == 1"</h3>
          </template>

          執行結果

          筆記分享

          <pre v-show="true">
              條件渲染:
              1、v-if
                  寫法:
                      (1)v-if = "表達式"
                      (2)v-else-if = "表達式"
                      (3)v-else = "表達式"
                  適用于:切換頻率較低的場景
                  特點:不展示的DOM元素將被直接刪除
                  注意:v-if和v-else-if、v-else一起使用的時候,要求結構不可以被打斷
              2、v-show
                  寫法:v-show = "表達式"
                  適用于:切換頻率較高的場景
                  特點:不展示的DOM元素未被移除,使用樣式進行隱藏
              3、備注
                  使用v-if時,元素可能無法獲取到,使用v-show是可獲取到的
              4、使用template v-if
                  寫的時候template對內容進行了包裹,
                  等最終頁面渲染的時候,將把template標簽刪掉,
                  這也就是說不破壞原來的樣式。
                  但是template只能配合v-if進行使用。
          </pre>

          源碼截圖


          主站蜘蛛池模板: 久久精品国产一区| 亚洲不卡av不卡一区二区| 88国产精品视频一区二区三区| 亚洲第一区二区快射影院| 久久久久久综合一区中文字幕| 国内精自品线一区91| 麻豆亚洲av熟女国产一区二| 韩日午夜在线资源一区二区| 国产成人综合精品一区| 日韩人妻无码一区二区三区综合部| 国产suv精品一区二区6| 精品无码中出一区二区| 一区二区免费在线观看| 夜夜嗨AV一区二区三区| 日本视频一区在线观看免费 | 亚洲一区二区三区在线播放| 日韩美一区二区三区| 动漫精品一区二区三区3d| 国产福利电影一区二区三区,亚洲国模精品一区 | 人妻内射一区二区在线视频| 狠狠色婷婷久久一区二区三区| 国产成人无码aa精品一区| 亚洲av日韩综合一区二区三区| 亚洲AV无码一区二区乱子伦| 成人精品视频一区二区三区不卡| 国产精品成人一区二区| 亚洲国产一区二区三区| 国产成人精品一区二三区| 无码一区二区三区免费| 欧美成人aaa片一区国产精品 | 97精品一区二区视频在线观看| 国产一区二区久久久| 久久99精品免费一区二区| 波多野结衣久久一区二区| 国产情侣一区二区三区| 免费高清在线影片一区| 国产观看精品一区二区三区| 国产福利电影一区二区三区,免费久久久久久久精 | 亚洲视频一区在线播放| 亚洲国产老鸭窝一区二区三区| 精品国产日产一区二区三区|