分步解析JavaScript实现tab选项卡自动切换功能


Posted in Javascript onJanuary 25, 2016

本文分享一个能够实现自动切换的选项卡功能,并给出它的具体实现过程。

关于选项卡大家一定不会陌生,应用非常的频繁,通常选项卡都是需要点击或者划过才能够实现切换。
代码实例如下:

<html>
<head>
<meta charset=" utf-8">
<title>tab切换</title>
<style type="text/css">
body,h2,p{
 margin:0px;
 padding:0px;
}ul,li{
 margin:0px;
 padding:0px;
 float:left;
 list-style-type:none;
 }
body{font-size:12px;}
.box{
 width:722px;
 height:99px;
 margin:10px auto;
 border:1px solid #dedede;
}
.list{
 width:711px;
 height:22px;
 float:left;
 padding:4px 0 0 9px;
 border-top:1px solid #fff;
 border-left:1px solid #fff;
 border-right:1px solid #fff;
}
.list li{
 width:74px;
 height:22px;
 float:left;
 cursor:pointer;
 color:#656565;
 line-height:22px;
 text-align:center;
}
.list li.hove{
 width:72px;
 height:20px;
 color:#fc6703;
 line-height:20px;
 border-top:1px solid #dedede;
 border-left:1px solid #dedede;
 border-right:1px solid #dedede;
 border-bottom:1px solid #fff;
 background:#fff;
}
.content{
 width:722px;
 height:72px;
 float:left;
 display:none;
}
</style>
<script>
function $(id){
 return typeof id === "string" ? document.getElementById(id) : id;
}
 
function $$(oParent, elem){
 return (oParent || document).getElementsByTagName(elem);
}
 
function $$$(oParent, sClass){
 var aElem = $$(oParent, '*');
 var aClass = [];
 var index = 0;
 for(index=0;index<aElem.length;index++){
 if(aElem[index].className == sClass){
  aClass.push(aElem[index]);
 }
 }
 return aClass;
}
 
function addEvent(oElm, strEvent, fuc) {
 addEventListener?oElm.addEventListener(strEvent,fuc,false):oElm.attachEvent('on'+strEvent,fuc);
};
function Tab(){
 this.initialize.apply(this, arguments);
}
 
 
Object.extend = function(destination, source) {
 for (var property in source) {
 destination[property] = source[property];
 }
 return destination;
};
 
Tab.prototype = {
 initialize : function(obj, dis, content, onEnd, eq){
 this.obj = $(obj);
 this.oList = $$$(this.obj, 'list')[0];
 this.aCont = $$$(this.obj, content);
 this.oUl = $$(this.oList, 'ul')[0];
 this.aLi = this.oUl.children;
 this.timer = null;
 eq ? (this.aLi.length < eq ? eq = 0 : eq) : eq = 0;
 this.oEve(onEnd);
 this.onEnd.method == 'mouseover' ? this.method = "mouseover" : this.method = "click";
 this.onEnd.autoplay == 'stop' ? this.autoplay = "stop" : this.autoplay = "play";
 this.aCont[eq].style.display = 'block';
 this.aLi[eq].className = 'hove';
 this.display(dis);
 this.autoPlayTab(eq, dis);
 },
 oEve: function(onEnd){
 this.onEnd = {
  method: 'mouseover',
  autoplay: 'stop',
 };
 Object.extend(this.onEnd, onEnd || {});
 },
 display : function(dis){
 var _this = this;
 var index = iNow = 0;
 for(index=0;index<_this.aLi.length;index++){
  (function(){
  var j = index;
  addEvent(_this.aLi[j], _this.method,
  function() {
   _this.fnClick(j,dis);
   _this.autoPlayTab(j, dis);
  })
  })()
 }
 },
 autoPlayTab : function(iNow, dis){
 if(this.autoplay == 'play'){
  var _this = this;
  this.iNow = iNow;
  this.obj.onmouseover = function(){
  clearInterval(_this.timer);
  };
  this.obj.onmouseout = function(){
  _this.timer = setInterval(playTab,5000);
  };
  clearInterval(_this.timer);
  _this.timer = setInterval(playTab,5000);
  function playTab(){
  if(_this.iNow == _this.aLi.length)_this.iNow = 0;
  _this.fnClick(_this.iNow, dis)
  _this.iNow++
  }
 }
 },
 fnClick : function(oBtn, dis){
 var index = 0;
 for(index=0;index<this.aLi.length;index++){
  this.aLi[index].className = '';
  this.aCont[index].style.display = 'none';
 }
 this.aLi[oBtn].className = dis;
 this.aCont[oBtn].style.display = 'block';
 }
};
window.onload = function(){
 new Tab("box", 'hove', 'content', {
 method : 'mouseover',
 autoplay : 'play'
 },0);
};
</script>
</head>
<body>
<div id="box" class="box">
 <div class="list">
 <ul>
  <li>div教程</li>
  <li>jquery教程</li>
  <li>css教程</li>
 </ul>
 </div>
 <div class="content">蚂蚁部落欢迎您</div>
 <div class="content">本站url地址是softwhy.com</div>
 <div class="content">只有努力才会有美好的未来</div>
</div>
</body>
</html>

上面的代码实现了我们的要求,下面介绍一下它的实现过程。
(1)模拟实现jQuery中的id选择器,参数是元素的id属性值

function $(id){
return typeof id === "string" ? document.getElementById(id) : id;
}

(2).function $$(oParent, elem){
  return (oParent || document).getElementsByTagName(elem);
},此函数实现了后去指定元素下所有特定元素的对象集合。
(3).此函数的功能是将oParent元素下所有class属性值为sClass的元素存入数组

function $$$(oParent, sClass){
 var aElem = $$(oParent, '*');
 var aClass = [];
 var index = 0;
 for(index=0;index<aElem.length;index++){
  if(aElem[index].className == sClass){
   aClass.push(aElem[index]);
  }
 }
 return aClass;
}

(4)事件处理函数的绑定封装,实现了浏览器兼容功能。

.function addEvent(oElm, strEvent, fuc) {
 addEventListener?oElm.addEventListener(strEvent,fuc,false) : oElm.attachEvent('on'+strEvent,fuc);
}

(5).此方法实现了基本的初始化操作

function Tab(){ this.initialize.apply(this, arguments);
}

(6).实现了合并对象的功能,比如可以将对象a中的属性合并到对象b中

Object.extend = function(destination, source) {
 for (var property in source) {
  destination[property] = source[property];
 }
 return destination;
}

(7).Tab.prototype = {},设置Tab构造函数的原型对象。
(8).initialize : function(obj, dis, content, onEnd, eq){},此方法可以进行一些初始化操作。第一个参数是元素id属性值,第二个参数是class样式类,第三个参数是内容div的class样式类名称,第四个参数是一个对象直接量,里面存储了一些相关参数,第五个参数规定默认哪个选项卡被选中,是一个数字。
(9).this.obj = $(obj),获取指定的元素对象。
(10).this.oList = $$$(this.obj, 'list')[0],获取class属性值为list的标题外层div元素。
(11).this.aCont = $$$(this.obj, content),获取选项卡内容元素集合。
(12).this.oUl = $$(this.oList, 'ul')[0],获取标题ul元素。
(13).this.aLi = this.oUl.children,获取ul元素下的所有子元素。
(14).this.timer = null,用作定时器函数的标识。
(15).eq ? (this.aLi.length < eq ? eq = 0 : eq) : eq = 0,如果eq是0则使用0,否则的话将使用eq传递的值,eq值要小于数组长度,否则eq值设置为0。
(16).this.oEve(onEnd),覆盖默认设置。
(17).this.onEnd.method == 'mouseover' ? this.method = "mouseover" : this.method = "click",判断是mouseover事件还是click事件。
(18).this.onEnd.autoplay == 'stop' ? this.autoplay = "stop" : this.autoplay = "play",默认是自动播放,否则就不是自动播放。
(19).this.aCont[eq].style.display = 'block',默认内容项显示。
(20).this.aLi[eq].className = 'hove',设置对应的标题选项卡样式。
(21).this.display(dis),注册事件处理函数,参数是一个样式类名称。
(22).this.autoPlayTab(eq, dis),执行此函数确保在允许自动切换的时候选项卡可以自动切换。
(23).

用来进行对象合并

oEve: function(onEnd){
 this.onEnd = {
  method: 'mouseover',
  autoplay: 'stop',
 };
 Object.extend(this.onEnd, onEnd || {});
}

这是默认的设置

this.onEnd = {
 method: 'mouseover',
 autoplay: 'stop',
}

如果传递了onend对象,就将其合并到默认对象,否则合并一个空对象

Object.extend(this.onEnd, onEnd || {})

(24).display : function(dis){},注册事件处理函数,参数是一个样式类名称。
(25).var _this = this,将this赋值给变量_this,为什么这么做后面会介绍。(26).var index = iNow = 0,进行一些初始化操作。
(27).for(index=0;index<_this.aLi.length;index++){},通过for循环遍历的方式注册事件处理函数。
(28)

.(function(){ var j = index;
 addEvent(_this.aLi[j], _this.method,
 function() {
  _this.fnClick(j,dis);
  _this.autoPlayTab(j, dis);
 })
})()

使用匿名自执行函数,其实就是形成了一个闭包。
之所以用闭包,是为了隔离匿名函数内部的index值和外部的index值。
之所以将this赋值给_this是因为,事件处理函数中的this是指向元素li的,而不是指向Tab()构造函数的对象实例。
(29).autoPlayTab : function(iNow, dis){},此函数实现了自动切换功能,第一个参数规定当前选项卡切换所处的索引位置,第二个参数一个样式类名称,就是设置处于当前状态的样式。
(30).if(this.autoplay == 'play'){},判断是否允许自动切换。
(31).var _this = this,将this赋值给变量_this,原理和上面是一样的。
(32).this.iNow = iNow,进行赋值操作。
(33).this.obj.onmouseover = function(){
  clearInterval(_this.timer);
},当鼠标悬浮的时候的时候停止定时器函数的执行,其实也就是停止自动切换。

(34).当鼠标离开的时候,开始自动切换动作

this.obj.onmouseout = function(){
 _this.timer = setInterval(playTab,5000);
}

(35).clearInterval(_this.timer),停止以前的定时器函数执行。
(36)._this.timer = setInterval(playTab,5000),开始自动切换。
(37).

function playTab(){
 if(_this.iNow == _this.aLi.length)_this.iNow = 0;
 _this.fnClick(_this.iNow, dis)
  _this.iNow++

}

不断调用此函数就实现了自动切换功能。
如果当前的索引等于li元素的个数,那么就将其设置为0,也就是从头进行新一轮切换。
然后调用对应的方法,并且让索引值自增。

(38)实现了选项卡的切换显示隐藏和样式设置效果

.fnClick : function(oBtn, dis){
  var index = 0;
  for(index=0;index<this.aLi.length;index++){
   this.aLi[index].className = '';
   this.aCont[index].style.display = 'none';
  }
  this.aLi[oBtn].className = dis;
  this.aCont[oBtn].style.display = 'block';
 }

以上就是本文的全部内容,希望对大家的学习有所帮助。

Javascript 相关文章推荐
捕获浏览器关闭、刷新事件不同情况下的处理方法
Jun 02 Javascript
JavaScript实现大数的运算
Nov 24 Javascript
Jquery幻灯片特效代码分享--打开页面随机选择切换方式(3)
Aug 15 Javascript
jQuery中cookie插件用法实例分析
Dec 04 Javascript
jQuery实现邮箱下拉列表自动补全功能
Sep 08 Javascript
JavaScript 中 avalon绑定属性总结
Oct 19 Javascript
浅谈angularjs依赖服务注入写法的注意点
Apr 24 Javascript
傻瓜式解读koa中间件处理模块koa-compose的使用
Oct 30 Javascript
Element Table的row-class-name无效与动态高亮显示选中行背景色
Nov 30 Javascript
微信小程序 授权登录详解(附完整源码)
Aug 23 Javascript
简单了解前端渐进式框架VUE
Jul 20 Javascript
react使用antd的上传组件实现文件表单一起提交功能(完整代码)
Jun 29 Javascript
jQuery form 表单验证插件(fieldValue)校验表单
Jan 24 #Javascript
Jquery实现纵向横向菜单
Jan 24 #Javascript
JavaScript、jQuery与Ajax的关系
Jan 24 #Javascript
JavaScript jquery及AJAX小结
Jan 24 #Javascript
基于JavaScript短信验证码如何实现
Jan 24 #Javascript
详解JS面向对象编程
Jan 24 #Javascript
js中实现字符串和数组的相互转化详解
Jan 24 #Javascript
You might like
自制短波长线天线频率预选器 - 成功消除B2K之流的镜像
2021/03/02 无线电
PHP 引用文件技巧
2010/03/02 PHP
php数组使用规则分析
2015/02/27 PHP
PHP实现GIF图片验证码
2015/11/04 PHP
CI框架实现cookie登陆的方法详解
2016/05/18 PHP
centos 7.2下搭建LNMP环境教程
2016/11/20 PHP
多广告投放代码 推荐
2006/11/13 Javascript
JavaScript中switch语句的用法详解
2015/06/03 Javascript
详解JavaScript中的构造器Constructor模式
2016/01/14 Javascript
灵活使用数组制作图片切换js实现
2016/07/28 Javascript
关于Vue.js一些问题和思考学习笔记(2)
2016/12/02 Javascript
Angular.js中定时器循环的3种方法总结
2017/04/27 Javascript
解决vue打包之后静态资源图片失效的问题
2018/02/21 Javascript
vue项目中使用lib-flexible解决移动端适配的问题解决
2018/08/23 Javascript
使用vscode快速建立vue模板过程详解
2019/10/10 Javascript
Vue和React有哪些区别
2020/09/12 Javascript
Python使用稀疏矩阵节省内存实例
2014/06/27 Python
详解Python中列表和元祖的使用方法
2015/04/25 Python
用pickle存储Python的原生对象方法
2017/04/28 Python
使用Python处理Excel表格的简单方法
2018/06/07 Python
Tensorflow中的placeholder和feed_dict的使用
2018/07/09 Python
pip安装py_zipkin时提示的SSL问题对应
2018/12/29 Python
python实现大转盘抽奖效果
2019/01/22 Python
Python初学者常见错误详解
2019/07/02 Python
深入浅析python变量加逗号,的含义
2020/02/22 Python
Django实现将views.py中的数据传递到前端html页面,并展示
2020/03/16 Python
初学者学习Python好还是Java好
2020/05/26 Python
Python 如何实现访问者模式
2020/07/28 Python
PyTorch中Tensor的数据类型和运算的使用
2020/09/03 Python
HTML最新标准HTML5总结(必看)
2016/06/13 HTML / CSS
运动会入场解说词300字
2014/01/25 职场文书
2014元旦晚会策划方案
2014/02/19 职场文书
教师思想工作总结2015
2015/05/13 职场文书
仓库管理制度范本
2015/08/04 职场文书
2016年圣诞节活动总结范文
2016/04/01 职场文书
幼师必备:幼儿园期末教师评语50条
2019/11/01 职场文书