国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > JavaScript > 正文

最簡(jiǎn)單純JavaScript實(shí)現(xiàn)Tab標(biāo)簽頁(yè)切換的方式(推薦)

2019-11-20 09:25:24
字體:
供稿:網(wǎng)友

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

Html:

<div class="tab-head"><h2 id="tab1" onmouseover="changeTab1()" class="selected">1</h2><h2 id="tab2" onmouseover="changeTab2()">2</h2><h2 id="tab3" onmouseover="changeTab3()">3</h2></div><div class="tab-content"><div id="c1" 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)顯而易見,有幾個(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就完全分離了,通過this指針就可以判斷當(dāng)前鼠標(biāo)滑過的是哪一個(gè)tab了。

以上所述是小編給大家介紹的最簡(jiǎn)單純JavaScript實(shí)現(xiàn)Tab標(biāo)簽頁(yè)切換的方式(推薦),希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)留言,小編會(huì)及時(shí)回復(fù)大家的,在此也非常感謝大家對(duì)武林網(wǎng)網(wǎng)站的支持!

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 赣州市| 建瓯市| 凌源市| 叙永县| 宁武县| 古田县| 纳雍县| 宁乡县| 安图县| 石首市| 重庆市| 鸡西市| 庆安县| 汝州市| 科尔| 清原| 乌鲁木齐市| 武定县| 夏津县| 南雄市| 怀化市| 岢岚县| 伽师县| 崇左市| 育儿| 金阳县| 诸暨市| 宜良县| 青阳县| 奎屯市| 进贤县| 泾阳县| 志丹县| 宾川县| 绩溪县| 读书| 水城县| 天镇县| 南丹县| 珲春市| 神农架林区|