首頁 web前端 css教學 用純CSS實施'顯示更多/更少”功能

用純CSS實施'顯示更多/更少”功能

Feb 24, 2025 am 09:24 AM

Implementing

>現代網絡開發通常利用CSS創建動態元素,例如滑塊,模態和工具提示,從而最大程度地減少JavaScript Reliance。本文展示了實現“顯示更多/更少”功能的純CSS方法,甚至創建了功能性手風琴風格的示例。 我們將探索技術,潛在問題和解決方案。 此處省略了可訪問性注意事項,但是未來改進的關鍵方面。

密鑰概念:

此CSS僅“顯示更多/不顯示”依賴於“ Checkbox Hack”和同胞選擇器。 HTML結構使用無序列表;最後一項包含隱藏的複選框及其標籤。嵌套的無序列表保留要顯示/隱藏的內容。

>和max-heightcss屬性控制光滑的揭示/隱藏。 可能存在瀏覽器不一致;例如,光標行為在瀏覽器中可能有所不同。 transition

基本CSS知識: 理解以下內容至關重要:

<ul>一般的同級選擇器(
  • :選擇所有兄弟姐妹遵循指定元素。 > ~
  • 相鄰的同胞選擇器(
  • :選擇立即在同胞之後。 > >
  • >複選框hack
  • :使用複選框的檢查狀態觸發CSS更改。
  • codepen演示(輸入中未提供的鏈接)提供了這些技術的交互式示例。 >

    html結構:

    基本的HTML結構是(從原來簡化):

    造型複選框容器:

    <ul>
      <li>Item 1</li>
      <li>Item 2</li>
      <li class="container">
        <input type="checkbox" id="showHide">
        <label for="showHide"></label>
        <ul>
          <li>Hidden Item 1</li>
          <li>Hidden Item 2</li>
        </ul>
      </li>
    </ul>
    登入後複製
    >

    樣式位置標籤並隱藏複選框:>

    使用偽元素(

    > and.container)來處理標籤的內容(“更多”或“更少”)和動畫。

    .container {
      position: relative;
      height: auto;
    }
    
    [type="checkbox"] {
      position: absolute;
      left: -9999px;
    }
    
    label {
      background: #e4e3df;
      display: block;
      width: 100%;
      height: 50px;
      cursor: pointer;
      position: absolute;
      top: 0;
    }
    登入後複製
    最初隱藏嵌套的

    與CSS:::before::after

    label:before,
    label:after {
      position: absolute;
    }
    
    /* ... (styles for :before and :after based on checked state) ... */
    登入後複製

    <ul>複選框的檢查狀態顯示隱藏的內容:

    [type="checkbox"] ~ ul {
      display: none;
    }
    登入後複製

    選中標籤的位置和內容:> onclick codepen演示(鏈接省略)展示此基本切換效果。 >

    添加平滑的過渡:

    [type="checkbox"]:checked ~ ul {
      display: block;
    }
    登入後複製

    對於平滑的過渡,使用

    >和
    [type="checkbox"]:checked + label {
      top: 100%;
    }
    
    /* ... (styles for :before and :after when checked) ... */
    登入後複製

    >

    標籤的過渡也已更新:

    codepen演示(省略鏈接)演示了改進的,更順暢的過渡。

    max-height transition瀏覽器注意事項:

    [type="checkbox"] ~ ul {
      overflow: hidden;
      max-height: 0;
      transition: max-height .45s cubic-bezier(.44,.99,.48,1);
    }
    
    [type="checkbox"]:checked ~ ul {
      max-height: 300px; /* Or a calculated height */
    }
    登入後複製
    請注意,光標行為在瀏覽器之間可能不一致(尤其是與過渡)。

    結論:
    label {
      transition: top .45s cubic-bezier(.44,.99,.48,1);
    }
    登入後複製

    >本文展示了一種功能強大的僅使用CSS的方法,用於“顯示更多/不顯示”功能。 儘管存在局限性(主要是瀏覽器不一致,並且需要預定的max-height),但該技術為許多情況提供了乾淨的,無JavaScript的解決方案。 請記住,在構建交互式組件時始終優先考慮可訪問性。

    >

    以上是用純CSS實施'顯示更多/更少”功能的詳細內容。更多資訊請關注PHP中文網其他相關文章!

    本網站聲明
    本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

    熱AI工具

    Undresser.AI Undress

    Undresser.AI Undress

    人工智慧驅動的應用程序,用於創建逼真的裸體照片

    AI Clothes Remover

    AI Clothes Remover

    用於從照片中去除衣服的線上人工智慧工具。

    Undress AI Tool

    Undress AI Tool

    免費脫衣圖片

    Clothoff.io

    Clothoff.io

    AI脫衣器

    Video Face Swap

    Video Face Swap

    使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

    熱門文章

    <🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
    3 週前 By 尊渡假赌尊渡假赌尊渡假赌
    北端:融合系統,解釋
    3 週前 By 尊渡假赌尊渡假赌尊渡假赌

    熱工具

    記事本++7.3.1

    記事本++7.3.1

    好用且免費的程式碼編輯器

    SublimeText3漢化版

    SublimeText3漢化版

    中文版,非常好用

    禪工作室 13.0.1

    禪工作室 13.0.1

    強大的PHP整合開發環境

    Dreamweaver CS6

    Dreamweaver CS6

    視覺化網頁開發工具

    SublimeText3 Mac版

    SublimeText3 Mac版

    神級程式碼編輯軟體(SublimeText3)

    熱門話題

    Java教學
    1664
    14
    CakePHP 教程
    1423
    52
    Laravel 教程
    1321
    25
    PHP教程
    1269
    29
    C# 教程
    1249
    24
    如何使用HTML,CSS和JavaScript創建動畫倒計時計時器 如何使用HTML,CSS和JavaScript創建動畫倒計時計時器 Apr 11, 2025 am 11:29 AM

    您是否曾經在項目上需要一個倒計時計時器?對於這樣的東西,可以自然訪問插件,但實際上更多

    HTML數據屬性指南 HTML數據屬性指南 Apr 11, 2025 am 11:50 AM

    您想了解的有關HTML,CSS和JavaScript中數據屬性的所有信息。

    當您看上去時,CSS梯度變得更好 當您看上去時,CSS梯度變得更好 Apr 11, 2025 am 09:16 AM

    我關注的一件事是Lea Verou&#039; s conic-Gradient()Polyfill的功能列表是最後一項:

    使Sass更快的概念證明 使Sass更快的概念證明 Apr 16, 2025 am 10:38 AM

    在一個新項目開始時,Sass彙編發生在眼睛的眨眼中。感覺很棒,尤其是當它與browsersync配對時,它重新加載

    靜態表單提供商的比較 靜態表單提供商的比較 Apr 16, 2025 am 11:20 AM

    讓我們嘗試在這裡造成一個術語:“靜態表單提供商”。你帶上html

    如何在WordPress主題中構建VUE組件 如何在WordPress主題中構建VUE組件 Apr 11, 2025 am 11:03 AM

    內聯式模板指令使我們能夠將豐富的VUE組件構建為對現有WordPress標記的逐步增強。

    php是A-OK用於模板 php是A-OK用於模板 Apr 11, 2025 am 11:04 AM

    PHP模板通常會因促進Subpar代碼而變得不良說唱,但這並不是這樣的情況。讓我們看一下PHP項目如何執行基本的

    三種代碼 三種代碼 Apr 11, 2025 pm 12:02 PM

    每次啟動一個新項目時,我都會將我正在查看的代碼分為三種類型,或者如果您願意的話。我認為這些類型可以應用於

    See all articles