JavaScript實現(xiàn)tab欄切換的幾種常用方法
更新時間:2023年12月15日 15:51:10 作者:清風(fēng)徐來。。。
這篇文章主要給大家介紹了關(guān)于JavaScript實現(xiàn)tab欄切換的幾種常用方法,在Web開發(fā)中Tab切換是一個常見的功能,它允許用戶在不同的頁面部分之間進行切換,需要的朋友可以參考下
整篇文章的基本html結(jié)構(gòu)和css樣式
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> <style> .tab{ width: 500px; height: 300px; border: 1px solid #cfc7c7; } .tab-nav{ display: flex; justify-content: space-between; align-items: center; margin: 20px; } .tab-nav .active{ color: red; border-bottom: 1px solid red; } .tab-nav ul{ width: 300px; height: 50px; display: flex; justify-content: space-between; align-items: center; list-style: none; margin-right: 40px; } .tab-nav ul li{ margin-right: 10px; } .tab-content{ width: 340px; height:190px; background-color: aquamarine; margin-top: -20px; margin-left: 120px; position: relative; } .item { width: 100%; height: 100%; position: absolute; } .item img{ width: 100%; height: 100%; display: none; } .active img{ display: block; } </style> </head> <body> <div class="tab"> <div class="tab-nav"> <h3>每日特價</h3> <ul> <!-- data-id對li元素添加自定義id屬性 --> <li class="active" data-id="0">精選</li> <li data-id="1">美食</li> <li data-id="2">百貨</li> <li data-id="3">預(yù)告</li> </ul> </div> <div class="tab-content"> <div class="item active"><img src="素材圖/js輪播圖/pic01.jpg" alt=""></div> <div class="item"><img src="素材圖/js輪播圖/pic02.jpg" alt=""></div> <div class="item"><img src="素材圖/js輪播圖/pic03.jpg" alt=""></div> <div class="item"><img src="素材圖/js輪播圖/pic04.jpg" alt=""></div> </div> </div> </body>
第一種方法:利用js控制 css的樣式進行對tab的內(nèi)容進行切換
//利用css樣式進行變換 //#region const Nav = document.querySelectorAll('.tab-nav li') for (let i = 0; i < Nav.length; i++) { Nav[i].addEventListener('click',function(){ //尋找class='.active'的結(jié)構(gòu),并將結(jié)構(gòu)中的該類名取消 document.querySelector('.tab-nav .active').classList.remove('active') //在對點擊對象的li中添加active類名,實現(xiàn)字體變色等css樣式 this.classList.add('active') //同樣移除tab-content結(jié)構(gòu)中的active類名 document.querySelector('.tab-content .active').classList.remove('active') //再對tab-content結(jié)構(gòu)中item的第幾個div添加active類名,實現(xiàn)圖片的出現(xiàn)和消失 //注意nth-child()中的值必須從1開始(不要了解可以去看css的偽類選擇器),i是從0開始,故要+1 document.querySelector(`.tab-content .item:nth-child(${i+1})`).classList.add('active') }) } //#endregion
第二種方法:利用事件委托(即事件冒泡)進行對tab欄的切換
//利用冒泡 //#region //利用ul統(tǒng)一管理li,應(yīng)為點擊時li元素,但li身上不存在點擊事件,于是便會冒泡到父級元素身上的點擊事件 //此方法減少了遍歷的消耗,提高代碼的效率與質(zhì)量 const ul = document.querySelector('.tab-nav ul') ul.addEventListener('click',(e)=>{ //e.target.tagName獲取鼠標(biāo)點擊對象的標(biāo)簽,為了區(qū)分特意加上了一個p標(biāo)簽,p不參與切換 if (e.target.tagName === 'LI') { document.querySelector('.tab-nav .active').classList.remove('active') //e.target獲取鼠標(biāo)點擊對象 e.target.classList.add('active') //此時難點就在于,如何將ul中的li元素和item結(jié)構(gòu)聯(lián)系起來,因為此時獲取的是ul結(jié)構(gòu)。 //本文里利用的是自定義屬性,對li元素設(shè)置id屬性 //利用變量i獲取點擊li元素身上的id屬性 const i =Number(e.target.dataset.id) //注意此處i是字符串型,必須進行轉(zhuǎn)換下面代碼的i+1才能使用 document.querySelector('.tab-content .active').classList.remove('active') document.querySelector(`.tab-content .item:nth-child(${i+1})`).classList.add('active') } }) //#endregion
第三種方法:利用數(shù)組的方法,對tab欄進行切換
//利用數(shù)組將li元素和item中的img元素進行一定的關(guān)系綁定,使其同步出現(xiàn)消失。 const Nav = document.querySelectorAll('.tab-nav li') const Content = document.querySelectorAll('.tab-content .item') //此處利用es6的擴展運算符,將Nav中的所有l(wèi)i元素張展開放在arr這個數(shù)組中,brr同理 let arr = [...Nav] let brr = [...Content] for (let i = 0; i <arr.length; i++) { arr[i].addEventListener('click',function(){ document.querySelector('.tab-nav .active').classList.remove('active') this.classList.add('active') document.querySelector('.tab-content .active').classList.remove('active') //如此通過變量i實現(xiàn)對li元素一一對應(yīng)上item結(jié)構(gòu)中的img brr[i].classList.add('active') }) }
總結(jié)
到此這篇關(guān)于JavaScript實現(xiàn)tab欄切換的幾種常用方法的文章就介紹到這了,更多相關(guān)JS實現(xiàn)tab欄切換內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
js刪除數(shù)組元素、清空數(shù)組的簡單方法(必看)
下面小編就為大家?guī)硪黄猨s刪除數(shù)組元素、清空數(shù)組的簡單方法(必看)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-07-07js 定時器setTimeout無法調(diào)用局部變量的解決辦法
javascript中定時器setTimeout無法調(diào)用局部變量,只需要將setTimeout的第一個參數(shù)改成函數(shù)對象,而不是字符串,就可以了2013-11-11Bootstrap基本插件學(xué)習(xí)筆記之Tooltip提示工具(18)
這篇文章主要為大家詳細介紹了Bootstrap基本插件學(xué)習(xí)筆記之oltip提示工具的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-12-12