亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

分步解析JavaScript實現tab選項卡自動切換功能

2019-11-20 10:42:48
字體:
來源:轉載
供稿:網友

本文分享一個能夠實現自動切換的選項卡功能,并給出它的具體實現過程。

關于選項卡大家一定不會陌生,應用非常的頻繁,通常選項卡都是需要點擊或者劃過才能夠實現切換。
代碼實例如下:

<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'; }

以上就是本文的全部內容,希望對大家的學習有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
精品久久中文字幕| 欧美大成色www永久网站婷| 国产精品一区二区电影| 亚洲精品日韩激情在线电影| 国产91精品久久久久久久| 欧美成人精品激情在线观看| 国产精品一区二区女厕厕| 超薄丝袜一区二区| 国产精品专区第二| 日本国产高清不卡| 日韩不卡在线观看| 国产精品69久久久久| 亚洲最大福利视频网站| 欧美影院成年免费版| 97福利一区二区| 精品性高朝久久久久久久| 91免费欧美精品| 欧美黑人xxx| 久久激情视频免费观看| 日韩欧美在线视频观看| 日韩欧美国产骚| 久久综合国产精品台湾中文娱乐网| 伊人激情综合网| 亚洲情综合五月天| 亚洲永久在线观看| 久久成年人视频| 欧美日韩福利视频| 色偷偷噜噜噜亚洲男人的天堂| 久久久久久网址| 亚洲福利视频在线| 91久久精品美女高潮| 国产精品av免费在线观看| 国产精品白丝av嫩草影院| 国产又爽又黄的激情精品视频| 国精产品一区一区三区有限在线| 97精品一区二区视频在线观看| 欧美午夜女人视频在线| 国模私拍一区二区三区| 久久久91精品| 国产精品69精品一区二区三区| 91po在线观看91精品国产性色| 九九精品在线观看| 欧美成人免费播放| 国产精品久久久久久久久久三级| 欧美俄罗斯性视频| 日韩在线视频观看| 欧美日韩日本国产| 九九九久久久久久| 国产精品专区一| 欧美极度另类性三渗透| 亚洲欧美成人网| 亚洲香蕉在线观看| 亚洲欧美一区二区三区久久| 91精品国产综合久久久久久蜜臀| 国产亚洲xxx| 国产日本欧美在线观看| 日韩av男人的天堂| 成人激情电影一区二区| 亚洲丝袜一区在线| 成人在线播放av| 欧美老妇交乱视频| 欧美大尺度激情区在线播放| 日韩最新在线视频| 欧美超级乱淫片喷水| 国产精自产拍久久久久久| 国产精品福利网| 国产丝袜一区二区三区免费视频| 久热在线中文字幕色999舞| 亚洲国产精久久久久久久| 91亚洲永久免费精品| 久久精品中文字幕| 成人激情免费在线| 中文字幕一区电影| 久久久www成人免费精品| 成人观看高清在线观看免费| 青青精品视频播放| 88国产精品欧美一区二区三区| 精品国产91久久久久久老师| 欧美精品成人91久久久久久久| 欧美日韩美女在线观看| 91精品国产91久久久久久久久| 欧美最猛性xxxxx亚洲精品| 日韩免费观看高清| 欧美日本黄视频| 奇米四色中文综合久久| 色综合老司机第九色激情| 精品国产欧美一区二区五十路| 久久久久国产视频| 欧美另类暴力丝袜| 亚洲欧美资源在线| 亚洲自拍中文字幕| 欧美成人精品在线播放| 欧美精品免费在线观看| 亚洲色图综合久久| 精品国产福利视频| 亚洲精品午夜精品| 91久久国产精品| 久久久精品影院| 法国裸体一区二区| 91久久久久久国产精品| 97精品一区二区三区| 精品视频在线观看日韩| 日韩亚洲第一页| 欧美xxxx14xxxxx性爽| 国内精品美女av在线播放| 欧美在线精品免播放器视频| 精品久久久久国产| 操人视频在线观看欧美| 欧美一级片在线播放| 日韩中文理论片| 欧美日韩第一视频| 成人国产精品一区二区| 欧美激情视频在线免费观看 欧美视频免费一| 亚洲成人激情小说| 97婷婷涩涩精品一区| 日韩一区二区福利| 97久久久免费福利网址| 久久久久久com| 91日本在线观看| 欧美极品美女视频网站在线观看免费| 亚洲成人1234| 91av视频导航| 日韩精品免费在线视频观看| 成年无码av片在线| 国产精品福利在线观看网址| 成人国内精品久久久久一区| 亚洲影院高清在线| 一区二区三区四区视频| 成人h片在线播放免费网站| 国产精品男女猛烈高潮激情| 欧美丰满老妇厨房牲生活| 日本成人激情视频| 91精品国产99久久久久久| 亚洲天堂av网| 美日韩精品免费观看视频| 国产精品电影在线观看| 国产精品成av人在线视午夜片| 欧美亚洲成人网| 精品久久久久久国产| 亚洲自拍中文字幕| 伊人久久免费视频| 91干在线观看| 亚洲美女在线看| 亚洲激情视频网站| 久久777国产线看观看精品| 97精品国产aⅴ7777| 亚洲欧美国内爽妇网| 久久久欧美一区二区| 久久久国产视频| www.99久久热国产日韩欧美.com| 亚洲国产精品久久91精品| 中文字幕日韩高清| 欧美激情精品久久久久久久变态| 亚洲亚裔videos黑人hd| 国产成人激情小视频| 欧美在线观看一区二区三区| 精品欧美aⅴ在线网站| 成人激情视频在线播放| 久久精品视频亚洲| 国产欧美日韩中文| 川上优av一区二区线观看| 国产精品女人久久久久久| 国产精品老女人精品视频| 欧美与黑人午夜性猛交久久久|