原生javascript實現(xiàn)圖片按鈕切換
更新時間:2015年01月12日 10:38:52 投稿:hebedich
這篇文章主要介紹了原生javascript實現(xiàn)圖片按鈕切換,需要的朋友可以參考下
先給大家看下效果展示圖

以下為詳細代碼:
復制代碼 代碼如下:
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; //圖片總數(shù)
this.nScollCount = option.scrollCount; //每次滾動的數(shù)量
this.nScollLen = Math.ceil(this.nLen/option.scrollCount); // 切換判斷的最大值
this.nSwitchWidth = 0; //每次切換移動的距離,在代碼里面動態(tài)獲取值
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(){
//動態(tài)獲取移動的寬度
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結(jié)構(gòu)必需是以下:外層ID名,自己傳入 如下面的:id="gy_picSwitch02" ,ID名,自己隨便給
但,里面的結(jié)構(gòu)必需一樣,包括類名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>
參數(shù):'wrapID':'xxxx',最外層的ID名
'scrollCount':5,滾動的數(shù)量
復制代碼 代碼如下:
*
*/
//實例化
new LGY_picSwitch({'wrapID':'gy_picSwitch','scrollCount':5});
是不是很方便的功能呢,使用也很簡單,這里推薦給小伙伴,希望對大家能有所幫助
相關文章
Javascript設計模式理論與編程實戰(zhàn)之簡單工廠模式
簡單工廠模式是由一個方法來決定到底要創(chuàng)建哪個類的實例, 而這些實例經(jīng)常都擁有相同的接口. 這種模式主要用在所實例化的類型在編譯期并不能確定, 而是在執(zhí)行期決定的情況。 說的通俗點,就像公司茶水間的飲料機,要咖啡還是牛奶取決于你按哪個按鈕2015-11-11
利用JavaScript做數(shù)獨的完整實現(xiàn)過程
數(shù)獨游戲是在一個9*9的方格中進行填數(shù)字的游戲,需要滿足的規(guī)則是每行每列和每個子九宮格都是1~9的不重復數(shù)字,下面這篇文章主要給大家介紹了關于如何利用JavaScript做數(shù)獨的相關資料,需要的朋友可以參考下2021-09-09
js給onclick事件賦值,動態(tài)傳參數(shù)實例解說
js動態(tài)給對象onclick事件賦值,動態(tài)傳參數(shù)舉兩個例子一對一錯,感興趣的朋友可以對比下,希望可以從中發(fā)現(xiàn)不一樣之處2013-03-03
UNIAPP實現(xiàn)微信小程序登錄授權(quán)和手機號授權(quán)功能(uniapp做微信小程序)
uniapp開發(fā)小程序,先授權(quán)用戶信息后再出現(xiàn)手機號授權(quán)的頁面進行手機號授權(quán),完成后返回上一頁面并把信息存入后臺以及前臺緩存中,方便使用,這篇文章主要介紹了UNIAPP實現(xiàn)微信小程序登錄授權(quán)和手機號授權(quán)(uniapp做微信小程序),需要的朋友可以參考下2024-08-08
JS實現(xiàn)對JSON數(shù)據(jù)進行冒泡排序
JavaScript 是一種廣泛使用的腳本語言,JSON是一種常見的數(shù)據(jù)格式,這篇文章主要來探討一下如何使用 JavaScript 對 JSON 數(shù)據(jù)進行冒泡排序,感興趣的可以了解一下2023-06-06

