JavaScript实现Tab标签页切换的最简便方式(4种)


Posted in Javascript onJune 28, 2020

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

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标签页切换的最简便方式(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 相关文章推荐
CSS+jQuery实现的一个放大缩小动画效果
Sep 24 Javascript
扩展jQuery对象时如何扩展成员变量具体怎么实现
Apr 25 Javascript
原生javascript实现获取指定元素下所有后代元素的方法
Oct 28 Javascript
SublimeText自带格式化代码功能之reindent
Dec 27 Javascript
jquery模拟实现鼠标指针停止运动事件
Jan 12 Javascript
jquery实现界面无刷新加载登陆注册
Jul 30 Javascript
微信小程序 网络请求(post请求,get请求)
Jan 17 Javascript
详解html-webpack-plugin用法全解
Jan 22 Javascript
AngularJS select加载数据选中默认值的方法
Feb 28 Javascript
记一次vue去除#问题处理经过小结
Jan 24 Javascript
如何使用three.js 制作一个三维的推箱子游戏
Jul 29 Javascript
浅谈javascript事件环微任务和宏任务队列原理
Sep 12 Javascript
vuex实现购物车功能
Jun 28 #Javascript
JavaScript图像放大镜效果实现方法详解
Jun 28 #Javascript
详细分析Node.js 模块系统
Jun 28 #Javascript
微信小程序实现拨打电话功能的示例代码
Jun 28 #Javascript
js瀑布流布局的实现
Jun 28 #Javascript
JavaScript如何使用插值实现图像渐变
Jun 28 #Javascript
vue实现登录拦截
Jun 29 #Javascript
You might like
Discuz 6.0+ 批量注册用户名
2009/09/13 PHP
解决PHP在DOS命令行下却无法链接MySQL的技术笔记
2010/12/29 PHP
深入PHP与浏览器缓存的分析
2013/06/03 PHP
php 备份数据库代码(生成word,excel,json,xml,sql)
2013/06/23 PHP
JSON字符串传到后台PHP处理问题的解决方法
2016/06/05 PHP
浅谈PHP匿名函数和闭包
2019/03/08 PHP
PHP常用函数之格式化时间操作示例
2019/10/21 PHP
aspx中利用js实现确认删除代码
2010/07/22 Javascript
JavaScript中去掉数组中的重复值的实现方法
2011/08/03 Javascript
查找iframe里元素的方法可传参
2013/09/11 Javascript
JavaScript获取页面上被选中文字的方法技巧
2015/03/13 Javascript
简介JavaScript中strike()方法的使用
2015/06/08 Javascript
利用jQuery实现打字机字幕效果实例代码
2016/09/02 Javascript
nodejs redis 发布订阅机制封装实现方法及实例代码
2016/12/15 NodeJs
jquery append与appendTo方法比较
2017/05/24 jQuery
Angular实现图片裁剪工具ngImgCrop实践
2017/08/17 Javascript
jquery+css3实现熊猫tv导航代码分享
2018/02/12 jQuery
d3.js实现自定义多y轴折线图的示例代码
2018/05/30 Javascript
Vue v-text指令简单使用方法示例
2019/09/19 Javascript
vue项目出现页面空白的解决方案
2019/10/31 Javascript
使用konva和vue-konva库实现拖拽滑块验证功能
2020/04/27 Javascript
Python实现识别手写数字 Python图片读入与处理
2020/03/23 Python
python中使用ctypes调用so传参设置遇到的问题及解决方法
2019/06/19 Python
pandas通过字典生成dataframe的方法步骤
2019/07/23 Python
Python3中urlencode和urldecode的用法详解
2019/07/23 Python
浅谈Python中threading join和setDaemon用法及区别说明
2020/05/02 Python
Python使用tkinter实现小时钟效果
2021/02/22 Python
日本高端护肤品牌:Tatcha
2016/08/29 全球购物
Dr. Martens马汀博士官网:马丁靴始祖品牌
2016/10/15 全球购物
小米旗下精品生活电商平台:小米有品
2018/12/18 全球购物
秦兵马俑教学反思
2014/02/07 职场文书
学校春季防火方案
2014/06/08 职场文书
校车安全责任书
2014/08/25 职场文书
停电放假通知
2015/04/14 职场文书
python读取并查看npz/npy文件数据以及数据显示方法
2022/04/14 Python
LyScript实现绕过反调试保护的示例详解
2022/08/14 Python