栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > Web开发 > JavaScript

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

JavaScript 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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

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

Html:


      

1

2

3 content1 content2 content3

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:


      

1

2

3 content1 content2 content3

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:


      

1

2

3 content1 content2 content3

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:


      

1 2 3 content1 content2 content3

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标签页切换内容请搜索考高分网以前的文章或继续浏览下面的相关文章希望大家以后多多支持考高分网!

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/69825.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号