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


Posted in Javascript onJuly 25, 2016

先说一下最土的一种方法:

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

效果:

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

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

Javascript 相关文章推荐
js导出txt示例代码
Jan 14 Javascript
用jQuery toggleClass 实现鼠标移上变色
May 14 Javascript
DOM基础教程之使用DOM控制表格
Jan 20 Javascript
JavaScript中数据结构与算法(四):串(BF)
Jun 19 Javascript
跟我学习javascript的定时器
Nov 19 Javascript
微信小程序 122100版本更新问题解决方案
Dec 22 Javascript
原生js实现吸顶效果
Mar 13 Javascript
Angular4项目中添加i18n国际化插件ngx-translate的步骤详解
Jul 02 Javascript
Node.js中使用mongoose操作mongodb数据库的方法
Sep 12 Javascript
原生js封装添加class,删除class的实例
Nov 06 Javascript
解决LayUI表单获取不到data的问题
Aug 20 Javascript
详解vue微信网页授权最终解决方案
Jun 16 Javascript
基于CSS3和jQuery实现跟随鼠标方位的Hover特效
Jul 25 #Javascript
javascript insertAfter()定义与用法示例
Jul 25 #Javascript
jquery之别踩白块游戏的简单实现
Jul 25 #Javascript
JavaScript禁止用户多次提交的两种方法
Jul 24 #Javascript
JavaScript表单焦点自动切换代码
Jul 24 #Javascript
javascript中sort排序实例详解
Jul 24 #Javascript
深入理解javascript作用域第二篇之词法作用域和动态作用域
Jul 24 #Javascript
You might like
亲密接触PHP之PHP语法学习笔记1
2006/12/17 PHP
php获取访问者IP地址汇总
2015/04/24 PHP
常规表格多表头查询示例
2014/02/21 Javascript
jQuery获取节点和子节点文本的方法
2014/07/22 Javascript
js与css实现弹出层覆盖整个页面的方法
2014/12/13 Javascript
javascript操作ul中li的方法
2015/05/14 Javascript
JS图片定时翻滚效果实现方法
2016/06/21 Javascript
JavaScript学习笔记整理_关于表达式和语句
2016/09/19 Javascript
javascript遍历json对象的key和任意js对象属性实例
2017/03/09 Javascript
微信小程序图片选择、上传到服务器、预览(PHP)实现实例
2017/05/11 Javascript
在React中如何优雅的处理事件响应详解
2017/07/24 Javascript
js/jQuery实现全选效果
2019/06/17 jQuery
Electron + vue 打包桌面操作流程详解
2019/06/24 Javascript
微信小程序学习总结(二)样式、属性、模板操作分析
2020/06/04 Javascript
JS数据类型判断的几种常用方法
2020/07/07 Javascript
axios封装与传参示例详解
2020/10/18 Javascript
js实现磁性吸附的示例
2020/10/26 Javascript
python uuid模块使用实例
2015/04/08 Python
Python实现的NN神经网络算法完整示例
2018/06/19 Python
Python socket套接字实现C/S模式远程命令执行功能案例
2018/07/06 Python
Python一行代码解决矩阵旋转的问题
2019/11/30 Python
基于Python生成个性二维码过程详解
2020/03/05 Python
使用pandas库对csv文件进行筛选保存
2020/05/25 Python
python如何利用paramiko执行服务器命令
2020/11/07 Python
HTML5离线应用与客户端存储的实现
2018/05/03 HTML / CSS
GAP欧盟网上商店:GAP EU
2016/09/13 全球购物
德国价格合理的品牌商品购物网站:averdo
2019/03/21 全球购物
护士自荐信怎么写
2013/10/18 职场文书
小学教师岗位职责
2013/11/25 职场文书
计算机求职信
2014/07/02 职场文书
2014年乡镇卫生院工作总结
2014/11/24 职场文书
接待员岗位职责范本
2015/04/15 职场文书
2015年村党支部工作总结
2015/04/30 职场文书
学校禁毒宣传活动总结
2015/05/08 职场文书
2016三八妇女节慰问信
2015/11/30 职场文书
pytorch锁死在dataloader(训练时卡死)
2021/05/28 Python