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

首頁 > 編程 > JavaScript > 正文

原生javascript實現圖片按鈕切換

2019-11-20 13:26:35
字體:
來源:轉載
供稿:網友

先給大家看下效果展示圖

以下為詳細代碼:

復制代碼 代碼如下:

function LGY_picSwitch(option){
    this.oWrap = this.getId(option.wrapID); //最外層元素
    this.olistWrap = this.getNodeByClassname(this.oWrap,'gy_picSwitch_listWrap')[0];
    this.oUl = this.olistWrap.getElementsByTagName('ul')[0];
    this.oBtnPrev = this.getNodeByClassname(this.oWrap,'gy_picSwitch_prev')[0];
    this.oBtnNext = this.getNodeByClassname(this.oWrap,'gy_picSwitch_next')[0];
    this.nLen = this.oUl.getElementsByTagName('li').length; //圖片總數
    this.nScollCount = option.scrollCount; //每次滾動的數量
    this.nScollLen = Math.ceil(this.nLen/option.scrollCount); // 切換判斷的最大值
    this.nSwitchWidth = 0; //每次切換移動的距離,在代碼里面動態獲取值
    this.nIndex = 0; //切換圖片的當前索引
    this.timer = null; //切換圖片的引值
    this.int();
}
LGY_picSwitch.prototype = {
    getId:function(id){
        return document.getElementById(id);
    },
    getNodeByClassname:function(parent,classname){
        var classElements = new Array();
        var els = parent.getElementsByTagName('*');
        var elsLen = els.length;
        var pattern = new RegExp("(^|//s)"+classname+"(//s|$)");
        for (i = 0, j = 0; i < elsLen; i++) {
                if ( pattern.test(els[i].className) ) {
                        classElements[j] = els[i];
                        j++;
                }
        }
        return classElements;
    },
    getCss:function(node,value)
    {
        return node.currentStyle?node.currentStyle[value]:getComputedStyle(node,null)[value];
    },
    setCss:function(node,val){
        for(var v in val){
            node.style.cssText += ';'+ v +':'+val[v];
        }
    },
    moveFn:function(node,value,targetValue,callback){
        var _that = this;
        clearInterval(this.timer);
        this.timer = setInterval(function()
        {
            var val = parseFloat(_that.getCss(node,value));
            var speed = ( targetValue- val )/8;
            speed = speed>0?Math.ceil(speed):Math.floor(speed);
            if(speed ==0)
            {
                clearInterval(_that.timer);
                callback&&callback();
            }
            else
            {                   
                node.style[value] = ( val + speed ) +'px';                   
            }
           
        },20);
    },
    picChange:function(){
        this.moveFn(this.oUl,'marginLeft',-this.nIndex*this.nSwitchWidth);
    },
    cancelBubble:function(e){
        e.stopPropagation?e.stopPropagation():e.cancelBubble = true;
    },
    btnIsShow:function(){
        this.setCss(this.oBtnNext,{'display':'block'});
        this.setCss(this.oBtnPrev,{'display':'block'});
        if( this.nIndex == 0 ) this.setCss(this.oBtnPrev,{'display':'none'});
        if( this.nIndex ==(this.nScollLen-1) ) this.setCss(this.oBtnNext,{'display':'none'});
    },
    btnPrev:function(){
        var _that = this;
        this.oBtnPrev.onclick = function(e){
            var e = e || window.event;
            _that.cancelBubble(e);
            if(_that.nIndex != 0 ) {
                _that.nIndex--;
                _that.picChange();
                _that.btnIsShow();
            }
        }
    },
    btnNext:function(){
        var _that = this;
        this.oBtnNext.onclick = function(e){
            var e = e || window.event;
            _that.cancelBubble(e);
            if(_that.nIndex != (_that.nScollLen-1) ) {
                _that.nIndex++;
                _that.picChange();
                _that.btnIsShow();
            }
        }
    },
    int:function(){
        //動態獲取移動的寬度
        var oLi = this.oUl.getElementsByTagName('li')[0],
            oLi_w = oLi.offsetWidth + parseInt(this.getCss(oLi,'marginLeft')) + parseInt(this.getCss(oLi,'marginRight'));
        this.nSwitchWidth = oLi_w*this.nScollCount;
        //按鈕顯示初始化
        this.btnIsShow();
        //左右切換
        this.btnPrev();
        this.btnNext();
    }
}

 
 HTML代碼:
復制代碼 代碼如下:

/*
* HTML結構必需是以下:外層ID名,自己傳入 如下面的:id="gy_picSwitch02" ,ID名,自己隨便給
但,里面的結構必需一樣,包括類名classname
<div id="gy_picSwitch02">
    <span class="gy_picSwitch_prev"></span>
    <span class="gy_picSwitch_next"></span>
    <div class="gy_picSwitch_listWrap">
        <ul>
            <li><img src="images/pic01.jpg" alt=""></li>
            <li><img src="images/pic02.jpg" alt=""></li>
            <li><img src="images/pic03.jpg" alt=""></li>
            <li><img src="images/pic04.jpg" alt=""></li>
            <li><img src="images/pic05.jpg" alt=""></li>
            <li><img src="images/pic06.jpg" alt=""></li>
            <li><img src="images/pic07.jpg" alt=""></li>
            <li><img src="images/pic08.jpg" alt=""></li>
        </ul>
    </div>
</div>

參數:'wrapID':'xxxx',最外層的ID名
      'scrollCount':5,滾動的數量  

復制代碼 代碼如下:
  
*
*/
//實例化
 new LGY_picSwitch({'wrapID':'gy_picSwitch','scrollCount':5});

是不是很方便的功能呢,使用也很簡單,這里推薦給小伙伴,希望對大家能有所幫助

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久99精品视频一区97| 一本色道久久88综合亚洲精品ⅰ| 一区二区三区视频免费| 日韩视频欧美视频| 欧美日韩人人澡狠狠躁视频| 国产91av在线| 福利视频第一区| 欧美在线影院在线视频| 蜜月aⅴ免费一区二区三区| 国内伊人久久久久久网站视频| 国产日韩欧美另类| 精品国产依人香蕉在线精品| 亚洲精品国精品久久99热一| 精品久久久av| 亚洲国产精品99久久| 国产日韩欧美在线观看| 国产成人av网| 国产91热爆ts人妖在线| 午夜精品视频在线| 亚洲精品永久免费| 欧美激情视频播放| 欧美性猛交xxxx黑人猛交| 亚洲欧洲在线观看| 色哟哟入口国产精品| 亚洲第一色在线| 91中文字幕在线| 欧美怡春院一区二区三区| 日韩一区二区精品视频| 中文字幕一区二区三区电影| 国产精品欧美在线| 久久久国产精品亚洲一区| 亚洲国产精彩中文乱码av在线播放| 国产精品免费久久久久久| 欧美精品成人91久久久久久久| 亚洲精品黄网在线观看| 日韩亚洲一区二区| 亚洲色图日韩av| 欧美最猛黑人xxxx黑人猛叫黄| 日本久久久久亚洲中字幕| 精品国内自产拍在线观看| 欧美综合在线第二页| 亚洲嫩模很污视频| 九色精品免费永久在线| 国产脚交av在线一区二区| 成人av资源在线播放| 韩日精品中文字幕| 日韩av电影院| 久久久久久中文| 日韩欧美亚洲范冰冰与中字| 精品av在线播放| 成人写真视频福利网| 久久久精品中文字幕| 夜夜嗨av一区二区三区免费区| 日韩av在线高清| 亚洲成人精品视频在线观看| 日本成人在线视频网址| 大胆人体色综合| 久久精品一区中文字幕| 欧美黑人又粗大| 欧美性猛交xxxx免费看漫画| 91精品国产综合久久香蕉922| 亚洲一级黄色av| 日本欧美在线视频| 中文字幕自拍vr一区二区三区| 黑人精品xxx一区| 亚洲一级一级97网| 国产精品三级网站| 国产亚洲日本欧美韩国| 欧美在线影院在线视频| 日韩精品在线第一页| 欧美日韩亚洲视频| 欧美性猛交xxxxx免费看| 亚洲精品在线91| 欧美大全免费观看电视剧大泉洋| 日韩在线国产精品| 欧美激情视频在线| 国产精品三级网站| 久久视频在线观看免费| 亚洲成人999| 国产精品欧美日韩| 久久久国产精品x99av| 亚洲奶大毛多的老太婆| 成人免费自拍视频| 日韩欧美国产骚| 国产成人在线一区二区| 91精品久久久久久久久青青| 欧美激情乱人伦| 亚洲小视频在线观看| 精品久久中文字幕| 日本久久中文字幕| 国产精品中文字幕久久久| 精品日韩视频在线观看| 国产精品影片在线观看| 成人免费福利视频| 国产精品中文久久久久久久| 精品国产福利在线| 日韩女优人人人人射在线视频| 久久久久久久久久av| 亚洲欧美日韩第一区| 精品日本高清在线播放| 日本中文字幕久久看| 最近2019年好看中文字幕视频| 久久久噜噜噜久久中文字免| 国产日韩欧美一二三区| 91精品国产高清久久久久久91| 国产偷国产偷亚洲清高网站| 欧美大片免费观看| 亚洲最大成人在线| 久久91亚洲精品中文字幕| 亚洲少妇中文在线| 国内精品中文字幕| 国产精品一区二区在线| 国产精品久久久久久婷婷天堂| 久久久精品国产一区二区| 久久久久女教师免费一区| 中日韩美女免费视频网址在线观看| 精品国产一区二区三区久久久狼| 亚洲国产精品人人爽夜夜爽| 久久久久久久久电影| 日韩国产精品一区| 欧美亚洲一区在线| 乱亲女秽乱长久久久| 久久噜噜噜精品国产亚洲综合| 欧美交受高潮1| 亚洲国产成人精品久久久国产成人一区| 日本成人精品在线| 亚洲精品电影久久久| 91a在线视频| 久久6精品影院| 国产人妖伪娘一区91| 亚洲аv电影天堂网| 久久久久免费视频| 日本中文字幕不卡免费| 日日噜噜噜夜夜爽亚洲精品| 91精品国产91久久久久久久久| 亚洲区免费影片| 爽爽爽爽爽爽爽成人免费观看| 亚洲视频电影图片偷拍一区| 国产一区二区三区久久精品| 中文字幕国产亚洲| 欧美综合在线观看| 国产精品视频在线观看| 成人国产精品免费视频| 精品久久久久久久久久久久| 96国产粉嫩美女| 97在线视频免费播放| 国产日韩欧美在线看| 97国产精品人人爽人人做| 欧美日韩午夜视频在线观看| 国产亚洲欧美aaaa| 亚洲精品98久久久久久中文字幕| 国产激情综合五月久久| 91久久精品国产| 国产视频观看一区| 91精品久久久久久久久久另类| 亚洲欧美中文字幕在线一区| 中文字幕欧美日韩va免费视频| 久久久视频免费观看| 欧美精品精品精品精品免费| 亚洲视频国产视频| 91久久久久久| 亚洲男人天堂视频| 国产中文字幕亚洲| 中文字幕日韩欧美精品在线观看|