JavaScript實(shí)現(xiàn)Tab標(biāo)簽頁(yè)切換的最簡(jiǎn)便方式(4種)
先說(shuō)一下最土的一種方法:
Html:
<div class='tab-head'> <h2 onmouseover='changeTab1()' class='selected'>1</h2> <h2 onmouseover='changeTab2()'>2</h2> <h2 onmouseover='changeTab3()'>3</h2> </div> <div class='tab-content'> <div class='show'>content1</div> <div id='c2'>content2</div> <div id='c3'>content3</div> </div>
CSS:
h2 {border-top: solid cornflowerblue 1px;border-left: solid cornflowerblue 1px;width: 50px;height: 25px;margin: 0;float: left;text-align: center; } .tab-content {border: solid cornflowerblue 1px;width: 152px;height: 100px; } .tab-content div{display: none; } .selected {background-color: cornflowerblue; } .tab-content .show{display: block; }
JS:
var tab1 = document.getElementById(’tab1’),tab2 = document.getElementById(’tab2’),tab3 = document.getElementById(’tab3’),c1 = document.getElementById(’c1’),c2 = document.getElementById(’c2’),c3 = document.getElementById(’c3’); function changeTab1() {tab1.className = ’selected’;tab2.className = ’’;tab3.className = ’’;c1.className = ’show’c2.className = ’’;c3.className = ’’; } function changeTab2() {tab1.className = ’’;tab2.className = ’selected’;tab3.className = ’’;c1.className = ’’;c2.className = ’show’;c3.className = ’’; } function changeTab3() {tab1.className = ’’;tab2.className = ’’;tab3.className = ’selected’;c1.className = ’’c2.className = ’’;c3.className = ’show’; }
效果:
實(shí)現(xiàn)Tab的切換,我們很容易想到的一種方式就是給每一個(gè)要控制的標(biāo)簽添加id,然后分別編寫鼠標(biāo)事件,使用id獲取每個(gè)元素,精確地控制每個(gè)元素的樣式。
這種方式的缺點(diǎn)顯而易見(jiàn),有幾個(gè)元素就有幾個(gè)id,每個(gè)tab都要編寫function,里面的方法大同小異。要增加tab的話,還要增加id和function,代碼冗余,不易擴(kuò)展。
第二種較為高明些的方法是編寫一個(gè)function,將每個(gè)元素的序號(hào)傳進(jìn)去。
Html:
<div class='tab-head'> <h2 onmouseover='changeTab(0)' class='selected'>1</h2> <h2 onmouseover='changeTab(1)'>2</h2> <h2 onmouseover='changeTab(2)'>3</h2> </div> <div class='tab-content'> <div class='show'>content1</div> <div>content2</div> <div>content3</div> </div>
JS:
var tabs = document.getElementsByClassName(’tab-head’)[0].getElementsByTagName(’h2’),contents = document.getElementsByClassName(’tab-content’)[0].getElementsByTagName(’div’); function changeTab(index) {for(var i = 0, len = tabs.length; i < len; i++) { if(i === index) { tabs[i].className = ’selected’; contents[i].className = ’show’; }else{ tabs[i].className = ’’; contents[i].className = ’’; }} }
這樣就只要寫一個(gè)function了,而且不需要id,但是還是要按照順序傳遞參數(shù)。
第三種方式和第二種基本一樣,只是參數(shù)傳遞的是this指針。
Html:
<div class='tab-head'> <h2 onmouseover='changeTab(this)' class='selected'>1</h2> <h2 onmouseover='changeTab(this)'>2</h2> <h2 onmouseover='changeTab(this)'>3</h2> </div> <div class='tab-content'> <div class='show'>content1</div> <div>content2</div> <div>content3</div> </div>
JS:
var tabs = document.getElementsByClassName(’tab-head’)[0].getElementsByTagName(’h2’),contents = document.getElementsByClassName(’tab-content’)[0].getElementsByTagName(’div’); function changeTab(tab) {for(var i = 0, len = tabs.length; i < len; i++) { if(tabs[i] === tab) { tabs[i].className = ’selected’; contents[i].className = ’show’; } else { tabs[i].className = ’’; contents[i].className = ’’; }} }
這種方式稍微方便一些,只要傳遞this指針,不用按照順序傳遞序號(hào),但這也不是最簡(jiǎn)便的方式。
最簡(jiǎn)便的一種:
第四種方式:
Html:
<div class='tab-head'> <h2 class='selected'>1</h2> <h2>2</h2> <h2>3</h2> </div> <div class='tab-content'> <div class='show'>content1</div> <div>content2</div> <div>content3</div> </div>
JS:
var tabs = document.getElementsByClassName(’tab-head’)[0].getElementsByTagName(’h2’),contents = document.getElementsByClassName(’tab-content’)[0].getElementsByTagName(’div’); (function changeTab(tab) {for(var i = 0, len = tabs.length; i < len; i++) { tabs[i].onmouseover = showTab;} })(); function showTab() {for(var i = 0, len = tabs.length; i < len; i++) { if(tabs[i] === this) { tabs[i].className = ’selected’; contents[i].className = ’show’; } else { tabs[i].className = ’’; contents[i].className = ’’; }} }
這樣JS、Html、CSS就完全分離了,通過(guò)this指針就可以判斷當(dāng)前鼠標(biāo)滑過(guò)的是哪一個(gè)tab了。
到此這篇關(guān)于JavaScript實(shí)現(xiàn)Tab標(biāo)簽頁(yè)切換的最簡(jiǎn)便方式(4種)的文章就介紹到這了,更多相關(guān)JavaScript Tab標(biāo)簽頁(yè)切換內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. css代碼優(yōu)化的12個(gè)技巧2. 微信開(kāi)發(fā) 網(wǎng)頁(yè)授權(quán)獲取用戶基本信息3. 爬取今日頭條Ajax請(qǐng)求4. jsp實(shí)現(xiàn)登錄驗(yàn)證的過(guò)濾器5. 詳解瀏覽器的緩存機(jī)制6. jsp EL表達(dá)式詳解7. asp批量添加修改刪除操作示例代碼8. msxml3.dll 錯(cuò)誤 800c0019 系統(tǒng)錯(cuò)誤:-2146697191解決方法9. jsp+servlet簡(jiǎn)單實(shí)現(xiàn)上傳文件功能(保存目錄改進(jìn))10. HTML5 Canvas繪制圖形從入門到精通
