亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

更多QQ空间微信QQ好友腾讯朋友复制链接
您的位置:首頁/技術文章
文章詳情頁

JavaScript實現Tab標簽頁切換的最簡便方式(4種)

【字号: 作者:豬豬瀏覽:24日期:2023-10-22 18:44:28

先說一下最土的一種方法:

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’; }

效果:

JavaScript實現Tab標簽頁切換的最簡便方式(4種)

實現Tab的切換,我們很容易想到的一種方式就是給每一個要控制的標簽添加id,然后分別編寫鼠標事件,使用id獲取每個元素,精確地控制每個元素的樣式。

這種方式的缺點顯而易見,有幾個元素就有幾個id,每個tab都要編寫function,里面的方法大同小異。要增加tab的話,還要增加id和function,代碼冗余,不易擴展。

第二種較為高明些的方法是編寫一個function,將每個元素的序號傳進去。

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 = ’’; }} }

這樣就只要寫一個function了,而且不需要id,但是還是要按照順序傳遞參數。

第三種方式和第二種基本一樣,只是參數傳遞的是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指針,不用按照順序傳遞序號,但這也不是最簡便的方式。

最簡便的一種:

第四種方式:

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就完全分離了,通過this指針就可以判斷當前鼠標滑過的是哪一個tab了。

到此這篇關于JavaScript實現Tab標簽頁切換的最簡便方式(4種)的文章就介紹到這了,更多相關JavaScript Tab標簽頁切換內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 色涩网站在线观看 | 国产精品最新 | 国产无内制服肉丝精品视频 | 久久涩精品 | 国产精品久久久久久吹潮 | 国产成人久久综合二区 | 美女大黄大色一级特级毛片 | 91福利视频合集 | 黄色视屏免费在线观看 | 精品视频在线观看你懂的一区 | 国产美女一区精品福利视频 | 最新国产美女一区二区三区 | 日日干天天草 | 中国一级毛片欧美一级毛片 | 国产成人啪午夜精品网站 | 亚洲精品午夜级久久久久 | 国产97公开成人免费视频 | 日韩中文字幕免费 | 在线精品视频免费观看 | 亚洲精品入口一区二区乱 | 久久99热狠狠色一区二区 | 亚洲成人精品视频 | 久久99国产精品久久欧美 | 俄罗斯一级成人毛片 | 免费人成网址在线观看国内 | 国产精品91视频 | 国产精品午夜久久 | 99热精品国产三级在线观看 | 黄色小视频免费在线观看 | 全部免费特黄特色大片视频 | 一级一片一a一片 | 国产乱辈通伦影片在线播放 | 亚洲欧美另类综合 | 亚洲美女视频一区 | 国产乱码亚洲精品一区二区 | 免费看黄色毛片 | 在线v| 免费网站在线观看国产v片 免费网站成人亚洲 | 久久er热在这里只有精品66 | 免费污污视频网站 | 欧美性生大片免费观看 |