分步解析JavaScript实现tab选项卡自动切换功能
本文分享一个能够实现自动切换的选项卡功能,并给出它的具体实现过程。
关于选项卡大家一定不会陌生,应用非常的频繁,通常选项卡都是需要点击或者划过才能够实现切换。
代码实例如下:
<html> <head> <metacharset="utf-8"> <title>tab切换</title> <styletype="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:10pxauto; border:1pxsolid#dedede; } .list{ width:711px; height:22px; float:left; padding:4px009px; border-top:1pxsolid#fff; border-left:1pxsolid#fff; border-right:1pxsolid#fff; } .listli{ width:74px; height:22px; float:left; cursor:pointer; color:#656565; line-height:22px; text-align:center; } .listli.hove{ width:72px; height:20px; color:#fc6703; line-height:20px; border-top:1pxsolid#dedede; border-left:1pxsolid#dedede; border-right:1pxsolid#dedede; border-bottom:1pxsolid#fff; background:#fff; } .content{ width:722px; height:72px; float:left; display:none; } </style> <script> function$(id){ returntypeofid==="string"?document.getElementById(id):id; } function$$(oParent,elem){ return(oParent||document).getElementsByTagName(elem); } function$$$(oParent,sClass){ varaElem=$$(oParent,'*'); varaClass=[]; varindex=0; for(index=0;index<aElem.length;index++){ if(aElem[index].className==sClass){ aClass.push(aElem[index]); } } returnaClass; } functionaddEvent(oElm,strEvent,fuc){ addEventListener?oElm.addEventListener(strEvent,fuc,false):oElm.attachEvent('on'+strEvent,fuc); }; functionTab(){ this.initialize.apply(this,arguments); } Object.extend=function(destination,source){ for(varpropertyinsource){ destination[property]=source[property]; } returndestination; }; 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; varindex=iNow=0; for(index=0;index<_this.aLi.length;index++){ (function(){ varj=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); functionplayTab(){ if(_this.iNow==_this.aLi.length)_this.iNow=0; _this.fnClick(_this.iNow,dis) _this.iNow++ } } }, fnClick:function(oBtn,dis){ varindex=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(){ newTab("box",'hove','content',{ method:'mouseover', autoplay:'play' },0); }; </script> </head> <body> <divid="box"class="box"> <divclass="list"> <ul> <li>div教程</li> <li>jquery教程</li> <li>css教程</li> </ul> </div> <divclass="content">蚂蚁部落欢迎您</div> <divclass="content">本站url地址是softwhy.com</div> <divclass="content">只有努力才会有美好的未来</div> </div> </body> </html>
上面的代码实现了我们的要求,下面介绍一下它的实现过程。
(1)模拟实现jQuery中的id选择器,参数是元素的id属性值
function$(id){
returntypeofid==="string"?document.getElementById(id):id;
}
(2).function$$(oParent,elem){
return(oParent||document).getElementsByTagName(elem);
},此函数实现了后去指定元素下所有特定元素的对象集合。
(3).此函数的功能是将oParent元素下所有class属性值为sClass的元素存入数组
function$$$(oParent,sClass){ varaElem=$$(oParent,'*'); varaClass=[]; varindex=0; for(index=0;index<aElem.length;index++){ if(aElem[index].className==sClass){ aClass.push(aElem[index]); } } returnaClass; }
(4)事件处理函数的绑定封装,实现了浏览器兼容功能。
.functionaddEvent(oElm,strEvent,fuc){ addEventListener?oElm.addEventListener(strEvent,fuc,false):oElm.attachEvent('on'+strEvent,fuc); }
(5).此方法实现了基本的初始化操作
functionTab(){this.initialize.apply(this,arguments); }
(6).实现了合并对象的功能,比如可以将对象a中的属性合并到对象b中
Object.extend=function(destination,source){ for(varpropertyinsource){ destination[property]=source[property]; } returndestination; }
(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).varindex=iNow=0,进行一些初始化操作。
(27).for(index=0;index<_this.aLi.length;index++){},通过for循环遍历的方式注册事件处理函数。
(28)
.(function(){varj=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).
functionplayTab(){ if(_this.iNow==_this.aLi.length)_this.iNow=0; _this.fnClick(_this.iNow,dis) _this.iNow++ }
不断调用此函数就实现了自动切换功能。
如果当前的索引等于li元素的个数,那么就将其设置为0,也就是从头进行新一轮切换。
然后调用对应的方法,并且让索引值自增。
(38)实现了选项卡的切换显示隐藏和样式设置效果
.fnClick:function(oBtn,dis){ varindex=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'; }
以上就是本文的全部内容,希望对大家的学习有所帮助。