JavaScript实现Tab选项卡切换


Posted in Javascript onFebruary 13, 2020

本文实例为大家分享了js实现选项卡切换的具体代码,供大家参考,具体内容如下

会用到原生js的dom操作

JavaScript实现Tab选项卡切换

html

<body>
 <div id="tab">
 <div id="tab_header">
  <ul>
  <li class="seclect">1</li>
  <li>2</li>
  <li>3</li>
  <li>4</li>
  <li>5</li>
  </ul>
 </div>
 <div id="tab_body">
  <div class="dom" style="display: block;">
  <ul>
   <li>1</li>
   <li>1</li>
   <li>1</li>
   <li>1</li>
  </ul>
  </div>
  <div class="dom">
  <ul>
   <li>2</li>
   <li>2</li>
   <li>2</li>
   <li>2</li>
  </ul>
  </div>
  <div class="dom">
  <ul>
   <li>3</li>
   <li>3</li>
   <li>3</li>
   <li>3</li>
  </ul>
  </div>
  <div class="dom">
  <ul>
   <li>4</li>
   <li>4</li>
   <li>4</li>
   <li>4</li>
  </ul>
  </div>
  <div class="dom">
  <ul>
   <li>5</li>
   <li>5</li>
   <li>5</li>
   <li>5</li>
  </ul>
  </div>
 </div>
</div>

css就不放了

js

window.onload = function(){
 var allLis = $('tab_header').getElementsByTagName('li');
 var allDoms = $('tab_body').getElementsByClassName('dom');
 console.log(allLis,allDoms);
 // 遍历拿到的allLis
 for(var i =0; i<allLis.length;i++){
 var li = allLis[i];
 li.index = i; 
 li.onmouseover = function(){
  // 排他思想 将所有的class清空
  for(var j = 0;j<allLis.length;j++){
  allLis[j].className = '';
  allDoms[j].style.display='none';
  }
  this.className = 'seclect';
  allDoms[this.index].style.display='block';
 }
 }
}
function $(id){
 return typeof id === "string" ? document.getElementById(id) : null;
}

这里面的 function $(id) 是我封装的一个dom id选择器,在里面先拿到准备操作的事件源,遍历拿到的数组,onmouseover鼠标移入时,再次遍历一数组,将数组里所有的classname 变为空,以及display样式隐藏,在移入时,移入哪个,给哪个赋值即可。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JS类定义原型方法的两种实现的区别评论很多
Sep 12 Javascript
Jquery replace 字符替换实现代码
Dec 02 Javascript
JS验证身份证有效性示例
Oct 11 Javascript
关于JS中match() 和 exec() 返回值和属性的测试
Mar 21 Javascript
使用Sticky组件实现带sticky效果的tab导航和滚动导航的方法
Mar 22 Javascript
原生JS实现在线问卷调查投票特效
Jan 03 Javascript
jquery ajaxfileupload异步上传插件使用详解
Feb 08 Javascript
AngularJS的$location使用方法详解
Oct 19 Javascript
详解vue-router 初始化时做了什么
Jun 11 Javascript
element-ui组件中input等的change事件中传递自定义参数
May 22 Javascript
解决微信小程序scroll-view组件无横向滚动的问题
Feb 04 Javascript
vue实现放大镜效果
Sep 17 Javascript
Angular 多模块项目构建过程
Feb 13 #Javascript
小程序卡片切换效果组件wxCardSwiper的实现
Feb 13 #Javascript
JavaScript实现省市区三级联动
Feb 13 #Javascript
jquery传参及获取方式(两种方式)
Feb 13 #jQuery
JS实现页面数据懒加载
Feb 13 #Javascript
node.js中fs文件系统模块的使用方法实例详解
Feb 13 #Javascript
原生JS与JQ获取元素的区别详解
Feb 13 #Javascript
You might like
并发下常见的加锁及锁的PHP具体实现代码
2010/10/12 PHP
PHP常量及变量区别原理详解
2020/08/14 PHP
PHP isset()及empty()用法区别详解
2020/08/29 PHP
jquery中防刷IP流量软件影响统计的一点对策
2011/07/10 Javascript
javascript表单验证使用示例(javascript验证邮箱)
2014/01/07 Javascript
Javascript字符串对象的常用方法简明版
2014/06/26 Javascript
node.js中的fs.statSync方法使用说明
2014/12/16 Javascript
jqueryUI里拖拽排序示例分析
2015/02/26 Javascript
Jquery实现textarea根据文本内容自适应高度
2015/04/03 Javascript
谈谈JavaScript类型系统之Math
2016/01/06 Javascript
JS代码实现table数据分页效果
2016/05/26 Javascript
JavaScript简单获取页面图片原始尺寸的方法
2016/06/21 Javascript
浅谈javascript中关于日期和时间的基础知识
2016/07/13 Javascript
javascript将url解析为json格式的两种方法
2017/08/18 Javascript
shiro授权的实现原理
2017/09/21 Javascript
node.js利用mongoose获取mongodb数据的格式化问题详解
2017/10/06 Javascript
监控Nodejs的性能实例代码
2019/07/02 NodeJs
python发送伪造的arp请求
2014/01/09 Python
Python中的多重装饰器
2015/04/11 Python
Python HTTP客户端自定义Cookie实现实例
2017/04/28 Python
python如何为被装饰的函数保留元数据
2018/03/21 Python
Django web框架使用url path name详解
2019/04/29 Python
pytorch 输出中间层特征的实例
2019/08/17 Python
Python任务自动化工具tox使用教程
2020/03/17 Python
Python ini文件常用操作方法解析
2020/04/26 Python
Python matplotlib可视化实例解析
2020/06/01 Python
Python 处理日期时间的Arrow库使用
2020/08/18 Python
Python装饰器如何实现修复过程解析
2020/09/05 Python
如何使用python自带IDLE的几种方法
2020/10/10 Python
python 自定义异常和主动抛出异常(raise)的操作
2020/12/11 Python
纽约著名的服装辅料来源:M&J Trimming
2017/07/26 全球购物
开业典礼主持词
2014/03/21 职场文书
公共场所标语
2014/06/30 职场文书
CSS实现单选折叠菜单功能
2021/11/01 HTML / CSS
MySQL详细讲解变量variables的用法
2022/06/21 MySQL
python如何利用cv2.rectangle()绘制矩形框
2022/12/24 Python