最简单纯JavaScript实现Tab标签页切换的方式(推荐)

先说一下最土的一种方法

Html:

rush:js;">
SEOver="changeTab1()" class="selected">1

SEOver="changeTab2()">2

SEOver="changeTab3()">3

CSS:

rush:js;"> 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:

rush: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'; }

效果

实现Tab的切换,我们很容易想到的一种方式就是给每一个要控制的标签添加id,然后分别编写鼠标事件,使用id获取每个元素,精确地控制每个元素的样式。

这种方式的缺点显而易见,有几个元素就有几个id,每个tab都要编写function,里面的方法大同小异。要增加tab的话,还要增加id和function,代码冗余,不易扩展。

第二种较为高明些的方法是编写一个function,将每个元素的序号传进去。

Html:

rush:js;">
SEOver="changeTab(0)" class="selected">1

SEOver="changeTab(1)">2

SEOver="changeTab(2)">3

content2
content3

JS:

rush: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:

rush:xhtml;">
SEOver="changeTab(this)" class="selected">1

SEOver="changeTab(this)">2

SEOver="changeTab(this)">3

content2
content3

JS:

rush: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:

rush:js;">

2

3

content2
content3

JS:

rush: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标签页切换的方式(推荐),希望对大家有所帮助,如果大家有任何疑问请留言,小编会及时回复大家的,在此也非常感谢大家对编程之家网站的支持

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...