JavaScript实现Tab标签页切换的最简便方式(4种)
作者:池月 时间:2024-04-17 10:30:36
先说一下最土的一种方法:
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';
}
效果:
实现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了。
来源:https://www.cnblogs.com/-867259206/p/5664896.html
标签:JavaScript,Tab,切换
0
投稿
猜你喜欢
golang如何通过viper读取config.yaml文件
2023-07-22 05:46:11
Vue父子组件传值的一些坑
2024-04-28 09:30:57
python安装教程 Pycharm安装详细教程
2022-08-08 02:25:55
Python新手如何进行闭包时绑定变量操作
2021-05-01 15:23:55
Python引用(import)文件夹下的py文件的方法
2023-09-28 11:14:00
Python对HTML转义字符进行反转义的实现方法
2022-07-27 08:44:34
python里dict变成list实例方法
2021-12-22 18:52:43
Python利用heapq实现一个优先级队列的方法
2021-08-05 06:28:48
Oracle 10g 服务器端安装预备步骤(详细图文教程)
2024-01-13 07:39:57
Python的进程,线程和协程实例详解
2021-05-05 04:35:59
Django中对通过测试的用户进行限制访问的方法
2021-08-27 16:42:46
详解eslint在vue中如何使用
2023-07-02 16:58:58
详解php中implode explode serialize json msgpack性能对比
2023-09-03 18:00:19
python中asyncio异步编程学习
2022-10-20 06:19:37
JS实现控制表格内指定单元格内容对齐的方法
2024-04-17 09:42:28
python中封包建立过程实例
2021-11-13 14:29:08
一次性彻底讲透Python中pd.concat与pd.merge
2023-02-06 19:04:33
Python3如何在服务器打印资产信息
2023-11-15 08:03:45
总结python中pass的作用
2021-02-15 18:34:45
mac安装scrapy并创建项目的实例讲解
2021-05-17 21:21:05