整合營銷服務商

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

          免費咨詢熱線:

          html多頁面實現背景音樂的連續播放,簡單處理筆記

          在多個HTML頁面之間切換時持續播放背景音樂,可以使用JavaScript和localStorage來實現。這里有一個簡單的實現方案:

          1. 創建一個隱藏的音頻播放器: 在每個HTML頁面的<body>標簽內添加一個隱藏的音頻標簽,并設置自動播放和循環播放屬性。
          1. 使用JavaScript控制音頻狀態: 當頁面加載時,檢查localStorage中是否有音樂正在播放的狀態,如果有,則恢復播放。同時,當頁面離開時,記錄音樂的播放狀態到localStorage。

          下面是一個簡化版的多頁面背景音樂連續播放的Demo示例。這個例子包含兩個HTML文件:index.html 和 page2.html。請確保你有相應的音頻文件(如music.mp3)并放置在與HTML文件相同的目錄下。

          index.html

          <!DOCTYPE html>
          <html lang="en">
              <head>
                  <meta charset="UTF-8" />
                  <title>首頁</title>
                  <style>
                      #backgroundMusic {
                          display: none;
                      }
                  </style>
              </head>
              <body>
                  <h1>首頁</h1>
                  <p>這是首頁,背景音樂會持續播放。</p>
                  <a href="page2.html">前往第二頁</a>
          
                  <audio controls id="backgroundMusic" loop>
                      <source src="https://img.mtsws.cn/LightPicture/2023/08/45f935a39d0189c0.mp3" type="audio/mpeg" />
                      您的瀏覽器不支持 audio 元素。
                  </audio>
          
                  <script>
                      document.addEventListener('DOMContentLoaded', function () {
                          var audio = document.getElementById('backgroundMusic')
                          setupMusic(audio)
                      })
          
                      function setupMusic(audio) {
                          var musicTime = parseFloat(localStorage.getItem('musicTime')) || 0
                          var isPlaying = localStorage.getItem('musicPlaying') === 'true'
          
                          audio.currentTime = musicTime
                          if (isPlaying) {
                              audio.play().catch(function (error) {
                                  console.error('自動播放被阻止:', error)
                              })
                          }
          
                          audio.onplay = function () {
                              localStorage.setItem('musicPlaying', true)
                          }
                          audio.onpause = function () {
                              localStorage.setItem('musicPlaying', false)
                          }
                          audio.ontimeupdate = function () {
                              localStorage.setItem('musicTime', audio.currentTime)
                          }
                      }
                  </script>
              </body>
          </html>
          

          page2.html

          <!DOCTYPE html>
          <html lang="en">
          <head>
              <meta charset="UTF-8">
              <title>第二頁</title>
              <style>
                  #backgroundMusic { display: none; }
              </style>
          </head>
          <body>
          
          <h1>第二頁</h1>
          <p>切換到第二頁,背景音樂仍然連續播放。</p>
          <a href="index.html">返回首頁</a>
          
          <audio id="backgroundMusic" src="music.mp3" loop></audio>
          
          <script>
              document.addEventListener('DOMContentLoaded', function() {
                  var audio = document.getElementById('backgroundMusic');
                  setupMusic(audio);
              });
          
              // 與index.html中相同的setupMusic函數,確保音樂播放邏輯一致
              function setupMusic(audio) {/*...函數內容與上文相同...*/}
          </script>
          </body>
          </html>

          在這個示例中,index.html 和 page2.html 都包含了相同的JavaScript邏輯來管理背景音樂的播放狀態和時間。當用戶在頁面間導航時,音樂將會無縫繼續播放,而不是重新開始。請根據實際需要調整音頻文件路徑和其他細節。

          您2019豬事順利,心想事成。

          前言

          Tab 切換是種很常見的網頁呈現形式,不管是PC或者H5都會經常看到,今天就為小伙伴們提供多種純CSS Tab 切換的實現方式,同時對比一下那種代碼更方便,更通俗易懂。

          3種純CSS方式實現Tab 切換

          純CSS實現都面臨2個問題:

          1、 如何接收點擊事件?

          2、 如何操作相關DOM?

          checked 偽類實現純 CSS Tab 切換

          擁有 checked 屬性的表單元素, <input type="radio"> 或者 <input type="checkbox"> 能夠接收到點擊事件。

          知識點:

          1、 使用 radio 標簽的 :checked 偽類,加上 <label for> 實現純 CSS 捕獲點擊事情

          2、 使用了 ~ 選擇符對樣式進行控制

          <div class="container"> 
           <input class="nav1" id="li1" type="radio" name="nav"> 
           <input class="nav2" id="li2" type="radio" name="nav"> 
           <ul class='nav'> 
           <li class='active'><label for="li1">tab1</label></li> 
           <li><label for="li2">tab2</label></li> 
           </ul> 
           <div class="content"> 
           <div class="content1 default">tab1 內容:123456</div> 
           <div class="content2">tab2 內容:abcdefgkijkl</div> 
           </div> 
          </div>
          

          添加樣式

          .container *{ 
           padding: 0; 
           margin: 0; 
          } 
          .container { 
           position: relative; 
           width: 400px; 
           margin: 50px auto; 
          } 
          .container input { 
           display: none; 
          } 
          .nav { 
           position: relative; 
           overflow: hidden; 
          } 
          .nav li { 
           width: 200px; 
           float: left; 
           text-align: center; 
           background: #ddd; 
           list-style: none; 
          } 
          .nav li label { 
           display: block; 
           width: 200px; 
           line-height: 36px; 
           font-size: 18px; 
           cursor: pointer; 
          } 
          .content { 
           position: relative; 
           overflow: hidden; 
           width: 400px; 
           height: 100px; 
           border: 1px solid #999; 
           box-sizing: border-box; 
           padding: 10px; 
          } 
          .content1, 
          .content2 { 
           display: none; 
           width: 100%; 
           height: 100%; 
          } 
          .nav1:checked ~ .nav li { 
           background: #ddd; 
           color: #000; 
          } 
          .nav1:checked ~ .nav li:first-child { 
           background: #ff7300; 
           color: #fff; 
          } 
          .nav2:checked ~ .nav li { 
           background: #ddd; 
           color: #000; 
          } 
          .nav2:checked ~ .nav li:last-child { 
           background: #ff7300; 
           color: #fff; 
          } 
          .nav1:checked ~ .content > div { 
           display: none; 
          } 
          .nav1:checked ~ .content > div:first-child { 
           display: block; 
          } 
          .nav2:checked ~ .content > div { 
           display: none; 
          } 
          .nav2:checked ~ .content > div:last-child { 
           display: block; 
          } 
          .nav li.active { 
           background: #ff7300; 
           color: #fff; 
          } 
          .content .default { 
           display: block; 
          }
          

          target 偽類實現純 CSS Tab 切換

          知識點:

          1、 要使用 :target 偽元素,需要 HTML 錨點,以及錨點對應的 HTML 片段

          2、 核心是使用 :target 偽類接收點擊事件

          3、 通過兄弟選擇符 ~ 控制樣式

          <div class="container"> 
           <div id="content1" class="active">tab 1內容:123456</div> 
           <div id="content2">tab 2內容:abcdefgkijkl</div> 
           
           <ul class='nav'> 
           <li class="active"><a href="#content1">tab1</a></li> 
           <li><a href="#content2">tab2</a></li> 
           </ul> 
           
           <div class="wrap"></div> 
          </div>
          

          添加樣式

          .container *{ 
           padding: 0; 
           margin: 0; 
          } 
          .container { 
           position: relative; 
           width: 400px; 
           margin: 50px auto; 
          } 
           
          .nav { 
           position: relative; 
           overflow: hidden; 
          } 
           
          li { 
           width: 200px; 
           float: left; 
           text-align: center; 
           background: #ddd; 
           list-style: none; 
          } 
           
          li a { 
           display: block; 
           width: 200px; 
           line-height: 36px; 
           font-size: 18px; 
           cursor: pointer; 
           text-decoration: none; 
           color: #000; 
          } 
           
          #content1, 
          #content2 { 
           position: absolute; 
           overflow: hidden; 
           top: 36px; 
           width: 400px; 
           height: 100px; 
           border: 1px solid #999; 
           box-sizing: border-box; 
           padding: 10px; 
          } 
           
          #content1, 
          #content2 { 
           display: none; 
           width: 100%; 
           background: #fff; 
          } 
           
          #content1:target, 
          #content2:target { 
           display: block; 
          } 
           
          #content1.active { 
           display: block; 
          } 
           
          .active ~ .nav li:first-child { 
           background: #ff7300; 
           color: #fff; 
          } 
           
          #content1:target ~ .nav li { 
           background: #ddd; 
           color: #000; 
          } 
          #content1:target ~ .nav li:first-child { 
           background: #ff7300; 
           color: #fff; 
          } 
           
          #content2:target ~ .nav li { 
           background: #ddd; 
           color: #000; 
          } 
          #content2:target ~ .nav li:last-child { 
           background: #ff7300; 
           color: #fff; 
          } 
           
          .wrap { 
           position: absolute; 
           overflow: hidden; 
           top: 36px; 
           width: 400px; 
           height: 100px; 
           border: 1px solid #999; 
           box-sizing: border-box; 
          }
          
          

          focus-within 來實現 tab 切換功能

          :focus-within 它表示一個元素獲得焦點,或該元素的后代元素獲得焦點。

          重點:它或它的后代獲得焦點。

          這也就意味著,它或它的后代獲得焦點,都可以觸發 :focus-within。

          知識點

          1、 這個屬性有點類似 Javascript 的事件冒泡,從可獲焦元素開始一直冒泡到根元素 html,都可以接收觸發 :focus-within 事件

          2、 本例子的思路就是通過獲焦態來控制其他選擇器,以及最重要的是利用了父級的 :not(:focus-within) 來設置默認樣式

          <div class="container"> 
           <div class="nav-box"> 
           <button class="nav1">tab1</button> 
           <button class="nav2">tab2</button> 
           <div class="content-box"> 
           <div class="content1"> 
           content-1 
           </div> 
           <div class="content2"> 
           content-2 
           </div> 
           </div> 
           </div> 
          </div>
          

          添加樣式

          .container { 
           width: 300px; 
           margin: 50px auto; 
           padding: 10px; 
           boder: 1px solid #ddd; 
          } 
           
          .nav-box { 
           font-size: 0; 
          } 
           
          button { 
           width: 150px; 
           height: 40px; 
           box-sizing: border-box; 
           outline: none; 
           background: #fff; 
           border: 1px solid #ddd; 
           font-size: 18px; 
           cursor: pointer; 
          } 
           
          button:focus-within { 
           color: #fff; 
           background: #ff7300; 
          } 
           
          .content-box { 
           font-size: 24px; 
           border: 1px solid #ddd; 
           height: 100px; 
          } 
          .content-box div { 
           display: none; 
          } 
           
          .nav-box:not(:focus-within) .nav1 { 
           color: #fff; 
           background: #ff7300; 
          } 
          .nav-box:not(:focus-within) .content1 { 
           display: block; 
          } 
           
          .nav1:focus-within ~ .content-box .content1 { 
           display: block; 
          } 
           
          .nav2:focus-within ~ .content-box .content2 { 
           display: block; 
          }
          
          

          3種純CSS方式實現Tab 切換

          這個效果就很差一些,因為,在tab失去焦點時,就會復原,回到tab1上面,并不推薦這種方式來實現。小編推薦第一種:checked實現方式,更容易理解。

          公告

          喜歡小編的點擊關注,了解更多知識!

          源碼地址和源文件下載請點擊下方“了解更多”

          行文本展開收起是一個很常見的交互, 如下圖演示



          實現這一類布局和交互難點主要有以下幾點


          1. 位于多行文本右下角的“展開收起”按鈕
          2. “展開”和“收起”兩種狀態的切換
          3. 當文本不超過指定行數時,不顯示“展開收起”按鈕


          說實話,之前單獨看這個布局,即使借助 JavaScript 也不是一件容易的事啊(需要計算文字寬度動態截取文本,vue-clamp 就是這么做的),更別說下面的交互和判斷邏輯了,不過經過我的一番琢磨,其實純 CSS 也能完美實現的,下面就一步一步來看看如何實現吧~



          一、位于右下角的“展開收起”按鈕


          很多設計同學都喜歡這樣的設計,把按鈕放在右下角,和文本混合在一起,而不是單獨一行,視覺上可能更加舒適美觀。先看看多行文本截斷吧,這個比較簡單


          1. 多行文本截斷


          假設有這樣一個 html 結構


          <div class="text">
            浮動元素是如何定位的
          正如我們前面提到的那樣,當一個元素浮動之后,它會被移出正常的文檔流,然后向左或者向右平移,一直平移直到碰到了所處的容器的邊框,或者碰到另外一個浮動的元素。
          </div>


          多行文本超出省略大家應該很熟悉這個了吧,主要用到用到 line-clamp ,關鍵樣式如下


          .text {
            display: -webkit-box;
            -webkit-line-clamp: 3;
            -webkit-box-orient: vertical;
            overflow: hidden;
          }



          1. 右下角環繞效果


          提到文本環繞效果,一般能想到 浮動 float ,沒錯,千萬不要以為浮動已經是過去式了,具體的場景還是很有用的。比如下面放一個按鈕,然后設置浮動


          <div class="text">
            <button class="btn">展開</button>
            浮動元素是如何定位的
          正如我們前面提到的那樣,當一個元素浮動之后,它會被移出正常的文檔流,然后向左或者向右平移,一直平移直到碰到了所處的容器的邊框,或者碰到另外一個浮動的元素。
          </div>


          .btn {
            float: left;
            /*其他裝飾樣式*/
          }



          如果設置右浮動


          .btn {
            float: right;
            /*其他裝飾樣式*/
          }



          這時已經有了環繞的效果了,只是位于右上角,如何將按鈕移到右下角呢?先嘗試一下 margin


          .btn {
            float: right;
            margin-top: 50px;
            /*其他裝飾樣式*/
          }



          可以看到,雖然按鈕到了右下角,但是文本卻沒有環繞按鈕上方的空間,空出了一大截,無能為力了嗎?


          雖然 margin 不能解決問題,但是整個文本還是受到了浮動按鈕的影響,如果有多個浮動元素會怎么樣呢?這里用偽元素來 ::before 代替


          .text::before{
            content: '';
            float: right;
            width: 10px;
            height: 50px;/*先隨便設置一個高度*/
            background: red
          }



          現在按鈕到了偽元素的左側,如何移到下面呢?很簡單,清除一下浮動 clear: both; 就可以了


          .btn {
            float: right;
            clear: both;
            /*其他裝飾樣式*/
          }



          可以看到,現在文本是完全環繞在右側的兩個浮動元素了,只要把紅色背景的偽元素寬度設置為0(或者不設置寬度,默認就是 0),就實現了右下角環繞的效果


          .text::before{
            content: '';
            float: right;
            width: 0; /*設置為0,或者不設置寬度*/
            height: 50px;/*先隨便設置一個高度*/
          }



          1. 動態高度


          上面雖然完成了右下加環繞,但是高度是固定的,如何動態設置呢?這里可以用到 calc 計算,用整個容器高度減去按鈕的高度即可,如下


          .text::before{
            content: '';
            float: right;
            width: 0;
            height: calc(100% - 24px);
          }


          很可惜,好像并沒有什么效果,打開控制臺看看,結果發現 calc(100% - 24px) 計算高度為 0



          原因其實很容易想到,就是 高度 100% 失效 的問題,關于這類問題網上的分析有很多,通常的解決方式是給父級指定一個高度,但是這里的高度是動態變化的,而且還有展開狀態,高度更是不可預知,所以設置高度不可取。


          除此之外,其實還有另一種方式,那就是利用 flex 布局。大概的方法就是在 flex 布局的子項中,可以通過百分比來計算變化高度,具體可參考 w3.org 中關于 css-flexbox 的描述


          If the flex item has align-self: stretch, redo layout for its contents, treating this used size as its definite cross size so that percentage-sized children can be resolved.


          因此,這里需要給 .text 包裹一層,然后設置 display: flex


          <div class="wrap">
            <div class="text">
              <button class="btn">展開</button>
              浮動元素是如何定位的
            正如我們前面提到的那樣,當一個元素浮動之后,它會被移出正常的文檔流,然后向左或者向右平移,一直平移直到碰到了所處的容器的邊框,或者碰到另外一個浮動的元素。
            </div>
          </div>


          .wrap{
            display: flex;
          }


          實踐下來,display: grid 和 display: -webkit-box 同樣有效,原理類似


          這樣下來,剛才的計算高度就生效了,改變文本的行數,同樣位于右下角~




          除此之外,動態高度也可以采用負的 margin 來實現(性能會比 calc 略好一點)


          .text::before{
            content: '';
            float: right;
            width: 0;
            /*height: calc(100% - 24px);*/
            height: 100%;
            margin-bottom: -24px;
          }


          到這里,右下角環繞的效果就基本完成,省略號也是位于展開按鈕之前的,完整代碼可以查看 codepen 右下角多行展開環繞效果


          4.其他瀏覽器的兼容處理


          上面的實現是最完美的處理方式。原本以為兼容性沒什么大問題的,畢竟只用到了文本截斷和浮動,-webkit-line-clamp 雖然是 -webkit- 前綴,不過 firefox 也是支持的,打開一看傻了眼,safarifirefox 居然全亂了!



          這就有點難受了,前面那么多努力都白費了嗎?不可能不管這兩個,不然就只能是 demo 了,無法用于生產環境。


          趕緊打開控制臺看看是什么原因。一番查找,結果發現是 display: -webkit-box !設置該屬性后,原本的文本好像變成了一整塊,浮動元素也無法產生環繞效果,去掉之后浮動就正常了



          那么問題來了:沒有 display: -webkit-box 怎么實現多行截斷呢 ?


          其實上面的努力已經實現了右下角環繞的效果,如果在知道行數的情況下設置一個最大高度,是不是也完成了多行截斷呢?為了便于設置高度,可以添加一個行高 line-height,如果需要設置成3行,那高度就設置成 line-height * 3


          .text {
            /*
            display: -webkit-box;
            -webkit-line-clamp: 3;
            -webkit-box-orient: vertical;
            */
            line-height: 1.5;
            max-height: 4.5em;
            overflow: hidden;
          }


          為了方便更好的控制行數,這里可以把常用的行數通過屬性選擇器獨立出來(通常不會太多),如下


          [line-clamp="1"] {
            max-height: 1.5em;
          }
          [line-clamp="2"] {
            max-height: 3em;
          }
          [line-clamp="3"] {
            max-height: 4.5em;
          }
          ...


          <!--3行-->
          <div class="text" line-clamp="3">
          ...
          </div>
          <!--5行-->
          <div class="text" line-clamp="5">
           ...
          </div>



          可以看到基本上正常了,除了沒有省略號,現在加上省略號吧,跟在展開按鈕之前就可以了,可以用偽元素實現


          .btn::before{
            content: '...';
            position: absolute;
            left: -10px;
            color: #333;
            transform: translateX(-100%)
          }



          這樣,SafariFirefox 的兼容布局基本上就完成了,完整代碼可以查看 codepen 右下角多行展開環繞效果(全兼容)


          二、“展開”和“收起”兩種狀態

          提到 CSS 狀態切換,大家都能想到 input type="checkbox" 吧。這里我們也需要用到這個特性,首先加一個 input ,然后把之前的 button 換成 label ,并且通過 for 屬性關聯起來


          <div class="wrap">
            <input type="checkbox" id="exp">
            <div class="text">
              <label class="btn" for="exp">展開</label>
              浮動元素是如何定位的
            正如我們前面提到的那樣,當一個元素浮動之后,它會被移出正常的文檔流,然后向左或者向右平移,一直平移直到碰到了所處的容器的邊框,或者碰到另外一個浮動的元素。
            </div>
          </div>


          這樣,在點擊 label 的時候,實際上是點擊了 input 元素,現在來添加兩種狀態,分別是只顯示 3 行和不做行數限制


          .exp:checked+.text{
            -webkit-line-clamp: 999; /*設置一個足夠大的行數就可以了*/
          }


          兼容版本可以直接設置最大高度 max-height 為一個較大的值,或者直接設置為 none


          .exp:checked+.text{
            max-height: none;
          }



          這里還有一個小問題,“展開”按鈕在點擊后應該變成“收起”,如何修改呢?


          有一個技巧,凡是碰到需要動態修改內容的,都可以使用偽類 content 生成技術,具體做法就是去除或者隱藏按鈕里面的文字,采用偽元素生成


          <label class="btn" for="exp"></label><!--去除按鈕文字-->


          .btn::after{
            content:'展開' /*采用content生成*/
          }


          添加 :checked 狀態


          .exp:checked+.text .btn::after{
            content:'收起'
          }


          兼容版本由于前面的省略號是模擬出來的,不能自動隱藏,所以需要額外來處理


          .exp:checked+.text .btn::before {
              visibility: hidden; /*在展開狀態下隱藏省略號*/
          }




          基本和本文開頭的效果一致了,完整代碼可以查看 codepen 多行展開收起交互,兼容版本可以查看 codepen 多行展開收起交互(全兼容)


          還有一點,如果給 max-height 設置一個合適的值,注意,是合適的值,具體原理可以參考CSS 奇技淫巧:動態高度過渡動畫,還能加上過渡動畫


          .text{
            transition: .3s max-height;
          }
          .exp:checked+.text{
            max-height: 200px; /*超出最大行高度就可以了*/
          }




          三、文本行數的判斷


          上面的交互已經基本滿足要求了,但是還是會有問題。比如當文本較少時,此時是沒有發生截斷,也就是沒有省略號的,但是“展開”按鈕卻仍然位于右下角,如何隱藏呢?



          通常 js 的解決方式很容易,比較一下元素的 scrollHeightclientHeight 即可,然后添加相對應的類名。下面是偽代碼


          if (el.scrollHeight > el.clientHeight) {
            // 文本超出了
            el.classList.add('trunk')
          } 


          那么,CSS 如何實現這類判斷呢?


          可以肯定的是,CSS 是沒有這類邏輯判斷,大多數我們都需要從別的角度,采用 “障眼法”來實現。比如在這個場景,當沒有發生截斷的時候,表示文本完全可見了,這時,如果在文本末尾添加一個元素(紅色小方塊),為了不影響原有布局,這里設置了絕對定位


          .text::after {
              content: '';
              width: 10px;
              height: 10px;
              position: absolute;
              background: red;
          }



          可以看到,這里的紅色小方塊是完全跟隨省略號的。當省略號出現時,紅色小方塊必定消失,因為已經被擠下去了,這里把父級 overflow: hidden 暫時隱藏就能看到是什么原理了



          然后,可以把剛才這個紅色的小方塊設置一個足夠大的尺寸,并且降低透明度,比如 100% * 100%


          .text::after {
              content: '';
              width: 100%;
              height: 100%;
              position: absolute;
              background: red;
          }




          可以看到,紅色的塊塊把右下角的都覆蓋了,現在把背景改為白色(和父級同底色),父級 overflow: hidden 重新加上


          .text::after {
              content: '';
              width: 100%;
              height: 100%;
              position: absolute;
              background: #fff;
          }



          現在看看點擊展開的效果吧



          現在展開以后,發現按鈕不見(被剛才那個偽元素所覆蓋,并且也點擊不了),如果希望點擊以后仍然可見呢?添加一下 :checked 狀態即可,在展開時隱藏覆蓋層


          .exp:checked+.text::after{
              visibility: hidden;
          }


          這樣,就實現了在文字較少的情況下隱藏展開按鈕的功能



          最終完整代碼可以查看 codepen 多行展開收起自動隱藏,兼容版本可以查看 codepen 多行展開收起自動隱藏(全兼容)


          需要注意的是,兼容版本可以支持到 IE 10+(這就過分了啊,居然還支持 IE),但是由于 IE 不支持 codepen,所以測試 IE 可以自行復制在本地測試。



          四、總結和說明


          總的來說,重點還是在布局方面,交互其實相對容易,整體實現的成本其實是很低的,也沒有比較生僻的屬性,除了布局方面 -webkit-box 貌似有點 bug (畢竟是-webkit-內核,火狐只是借鑒了過來,難免有些問題),幸運的是可以通過另一種方式實現多行文本截斷效果,兼容性相當不錯,基本上全兼容(IE10+),這里整理一下實現重點


          1. 文本環繞效果首先考慮 浮動 float
          2. flex 布局子元素可以通過百分比計算高度
          3. 多行文本截斷還可以結合文本環繞效果用 max-height 模擬實現
          4. 狀態切換可以借助 checkbox
          5. CSS 改變文本可以采用偽元素生成
          6. 多利用 CSS 遮擋“障眼法”


          多行文本展開收起效果可以說是業界一個老大難的問題了,有很多 js 解決方案,但是感覺都不是很完美,希望這個全新思路的 CSS 解決方式能給各位帶來不一樣的啟發,感謝閱讀,歡迎點贊、收藏、轉發~


          References

          [1] vue-clamp: https://justineo.github.io/vue-clamp/demo/?lang=zh

          [2] css-flexbox: https://www.w3.org/TR/css-flexbox-1/#algo-stretch

          [3] codepen 右下角多行展開環繞效果: https://codepen.io/xboxyan/pen/ExWaBJO

          [4] codepen 右下角多行展開環繞效果(全兼容): https://codepen.io/xboxyan/pen/dyvYNxr

          [5] codepen 多行展開收起交互: https://codepen.io/xboxyan/pen/XWMbJeQ

          [6] codepen 多行展開收起交互(全兼容): https://codepen.io/xboxyan/pen/OJpypmR

          [7] CSS 奇技淫巧:動態高度過渡動畫: https://github.com/chokcoco/iCSS/issues/91

          [8] codepen 多行展開收起自動隱藏: https://codepen.io/xboxyan/pen/eYvNvYK

          [9] codepen 多行展開收起自動隱藏(全兼容): https://codepen.io/xboxyan/pen/LYWpWzK


          主站蜘蛛池模板: 亚洲国产精品一区二区第一页免| 亲子乱av一区二区三区| 亚洲色无码专区一区| 无码AV一区二区三区无码| 国产一区美女视频| 亚洲午夜精品第一区二区8050| 国产AⅤ精品一区二区三区久久| 成人午夜视频精品一区| 久久亚洲AV午夜福利精品一区| 蜜臀AV免费一区二区三区| 怡红院一区二区在线观看| 波霸影院一区二区| 国产精品区一区二区三在线播放 | 亚洲一区二区高清| 成人免费区一区二区三区| 99精品一区二区三区无码吞精| 免费高清av一区二区三区| 好爽毛片一区二区三区四| 亚洲Av高清一区二区三区| 国产成人一区二区三区电影网站 | 日韩一区二区三区射精| 一区二区三区免费精品视频| 精品国产亚洲一区二区三区| 蜜臀AV一区二区| 国产主播一区二区三区在线观看| 中文字幕一区二区三区视频在线| 亚洲国产福利精品一区二区| 免费观看日本污污ww网站一区 | 麻豆果冻传媒2021精品传媒一区下载 | 亚洲无删减国产精品一区| 国产精品视频一区| 精品国产免费一区二区三区香蕉| 亚洲欧美日韩中文字幕一区二区三区| 成人在线一区二区| 亚洲一区二区三区播放在线| 国精品无码A区一区二区| 亚洲AV成人一区二区三区在线看| 国产激情无码一区二区三区| 久久精品日韩一区国产二区| 国精品无码一区二区三区在线| 日本免费电影一区|