CSS3+HTML5+JS 實現(xiàn)一個塊的收縮與展開動畫效果

最近在做項目時,發(fā)現(xiàn)CSS3中關于動畫的技術,自己很少運用在項目中,平時一些列表塊的收縮和展開動畫效果,幾乎都是使用 display 的 none 和 block,或者 visibility 的 hidden 和 visible 來進行控制。因此,在最近的項目中,就開始深入研究CSS3關于動畫的技術,并且運用到了項目中,下面是關于列表塊的收縮&展開動畫。
簡單的一個效果圖
實現(xiàn)思路
大體上我們將列表塊分割成 標題塊 和 內(nèi)容塊
(1)標題塊: 展示標題和一個帶有收縮&展開動畫效果的圖標
①圖標部分,我們可以使用偽類來繪畫出箭頭,并且使用 transform 的旋轉屬性 rotate 進行圖標的方向控制和其動畫效果。
②動畫控制,通常點擊標題部分,列表則收縮&展開,因此點擊標題時,要對class進行控制。
(2)內(nèi)容塊:內(nèi)容塊展示內(nèi)容,且該塊承載了主要的動畫效果——列表的收縮&展開
?、賱赢嬓Ч涸搲K的動畫,我們的思路是整個塊的高度收起來,里面的內(nèi)容也向左邊隱藏,因此需要控制高度和動畫的隱藏,所以使用 max-height 進行高度控制和 transition(設置動畫時間)、transform 的屬性 translate 來進行內(nèi)容的隱藏
完整代碼如下:
<!DOCTYPE html> <html> <head> <title></title> <style type="text/css"> .block_wrap { width: 500px; margin: 0 auto; border: 1px solid #e3e3e3; border-radius: 10px; } .chapter_wrap { background: white; text-align: left; border-radius: 8px; color: #333333; margin-bottom: 15px; font-size: 14px; overflow: hidden; } .title_item_wrap { padding: 10px 10px 10px 0; margin: 0 10px 0 10px; border-bottom: none; display: flex; align-items: center; } /*使用偽類進行圖標繪畫*/ .title_item_wrap::after { content: ''; width: 10px; height: 10px; border-top: 2px solid #999999; border-right: 2px solid #999999; transform: rotate(-45deg); display: inline-block; transition: 0.3s; float: right; margin-top: 10px; } /*使用類acitve類控制圖標的旋轉和展開時標題的下邊界*/ .active { border-bottom: 1px solid #F0F0F0; } .active::after{ transform: rotate(135deg); margin-top: 5px; } .chapter_title { font-size: 16px; padding: 0; margin: 0; width: calc(100% - 30px); } .node_wrap { overflow: hidden; overflow-y: scroll; transition: 0.3s; } .node_wrap p { padding: 0 20px 5px 20px; margin: 10px 0; border-bottom: 1px solid #e3e3e3 } /*隱藏內(nèi)容塊的滑動條*/ .node_wrap::-webkit-scrollbar { display: none; } /*控制內(nèi)容塊隱藏 隱藏時,整塊向左邊平移200%的寬度,并且將最大高度設置為0,否則頁面會留有空白*/ .node_wrap_hide { transform: translate(-200%, 0); max-height: 0; } /*控制內(nèi)容塊顯示,顯示時,整塊向右邊復原,并且將最大高度設置為300px,里面的內(nèi)容即會將塊撐開*/ .node_wrap_show { transform: translate(0, 0); max-height: 300px; } </style> </head> <body> <div class="block_wrap"> <div id="block_wrap" class="title_item_wrap active"> <p class="chapter_title">章節(jié)名稱</p> </div> <div id="list_wrap" class="node_wrap node_wrap_show"> <p>節(jié)名稱一</p> <p>節(jié)名稱二</p> <p>節(jié)名稱三</p> <p>節(jié)名稱四</p> <p>節(jié)名稱五</p> <p>節(jié)名稱六</p> <p>節(jié)名稱七</p> <p>節(jié)名稱八</p> <p>節(jié)名稱九</p> <p>節(jié)名稱十</p> </div> </div> </body> <script type="text/javascript"> // 獲取標題元素 var block_wrap = document.getElementById('block_wrap') //給標題元素添加點擊事件,通過點擊控制class的添加&去除達成動畫效果 block_wrap.onclick = function() { // 獲取標題元素className集合 let classArray = this.className.split(/\s+/) // 獲取內(nèi)容塊元素 let list_wrap = document.getElementById('list_wrap') // 判斷標題元素是否有類active,如若存在,則說明列表展開,這時點擊則是隱藏內(nèi)容塊,否則顯示內(nèi)容塊 if (classArray.includes('active')) { // 隱藏內(nèi)容塊 block_wrap.classList.remove('active') list_wrap.classList.remove('node_wrap_show') list_wrap.classList.add('node_wrap_hide') console.log(this.className.split(/\s+/)) return } else { // 顯示內(nèi)容塊 block_wrap.classList.add('active') list_wrap.classList.add('node_wrap_show') list_wrap.classList.remove('node_wrap_hide') return } } </script> </html>
以上代碼直接復制到HTML文件保存后即可看到效果。此動畫效果適應移動端,PC端會有點瑕疵,稍微處理即可。
到此這篇關于CSS3+HTML5+JS 實現(xiàn)一個塊的收縮與展開動畫效果的文章就介紹到這了,更多相關html5展開收縮動畫內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章,希望大家以后多多支持腳本之家!
相關文章
- 這篇文章主要介紹了如何使用CSS3 實現(xiàn)側邊欄展開收起動畫,并附上了示例代碼,非常的詳細,推薦給需要的小伙伴。2014-12-22
CSS3超酷環(huán)形動畫菜單其子菜單可環(huán)繞展開
一款非常有創(chuàng)意的CSS3動畫菜單,菜單是環(huán)形的2014-05-28CSS3華麗的Tab菜單當鼠標滑過時會出現(xiàn)展開動畫
這款Tab菜單的菜單項是一個個小圖標,鼠標滑過時,菜單項展示對應文字,并出現(xiàn)展開的動畫2014-05-04純CSS3實現(xiàn)的橫向和縱向鼠標滑過手風琴自動展開效果
無需任何js代碼,純CSS3實現(xiàn),鼠標滑過自動展開,可以實現(xiàn)橫向和縱向的手風琴效果2013-06-07基于jquery+css3實現(xiàn)左右搖擺可滑動展開折疊圓形導航菜單
CSS3實現(xiàn)的一些菜單導航效果,在不支持CSS3屬性的瀏覽器下效果較差一些,展開效果后會看到文字、搜索框等等2013-02-20