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

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

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

rush:xhtml;"> <Meta charset=" utf-8"> tab切换
Box" class="Box">
  • div教程
  • jquery教程
  • css教程
  • URL地址是softwhy.com

    上面的代码实现了我们的要求,下面介绍一下它的实现过程。

    (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的元素存入数组

    rush:js;"> function $$$(oParent,'*'); var aClass = []; var index = 0; for(index=0;index

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

    rush:js;"> .function addEvent(oElm,false) : oElm.attachEvent('on'+strEvent,fuc); }

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

    rush:js;"> function Tab(){ this.initialize.apply(this,arguments); }

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

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

    (7).Tab.prototype = {},设置Tab构造函数的原型对象。 (8).initialize : function(obj,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).

    用来进行对象合并

    rush:js;"> oEve: function(onEnd){ this.onEnd = { method: 'mouSEOver',onEnd || {}); }

    这是认的设置

    rush:js;"> this.onEnd = { method: 'mouSEOver',}

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

    rush:js;"> 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)

    rush:js;"> .(function(){ var j = index; addEvent(_this.aLi[j],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).当鼠标离开的时候,开始自动切换动作

    rush:js;"> this.obj.onmouSEOut = function(){ _this.timer = setInterval(playTab,5000); }

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

    rush:js;"> function playTab(){ if(_this.iNow == _this.aLi.length)_this.iNow = 0; _this.fnClick(_this.iNow,dis) _this.iNow++

    }

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

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

    rush:js;"> .fnClick : function(oBtn,dis){ var index = 0; for(index=0;indexdisplay = 'none'; } this.aLi[oBtn].className = dis; this.aCont[oBtn].style.display = 'block'; }

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

    相关文章

    前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
    前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
    前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
    前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
    前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
    前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...