JS無縫滾動效果實現(xiàn)方法分析
本文實例講述了JS無縫滾動效果實現(xiàn)方法。分享給大家供大家參考,具體如下:

效果:
1.默認(rèn)緩慢往左滾動
2.放到左箭頭上還是向左滾動,放到右箭頭上向右滾動
3.放到圖片上停止?jié)L動,移出繼續(xù)滾動
思路:
1.計算圖片列表ul的寬度
2.開啟定時器,使其向左邊距不斷增大,造成向左運(yùn)動的效果
3.圖片列表復(fù)制一份,向左移動時,當(dāng)左邊距大于一份的寬度時,把它的左邊距拉回到0。向右移動時,當(dāng)左邊距大于0時,把它的左邊距拉到整個兩份圖片列表一半的寬度(即一份的寬度)。(拉的瞬間很快,用戶察覺不到,造成一種無縫滾動的假象)
4.offsetLeft值的正負(fù)決定往哪邊移動
5.放到圖片上停止這個定時器,移開再開啟
window.onload=function(){
var odiv=document.getElementById('div');
var oul=odiv.getElementsByTagName('ul')[0];
var oli=oul.getElementsByTagName('oul');
var btn=document.getElementsByTagName('btn');
var ispeed=-1;
var timer=null;
oul.innerHTML+=oul.innerHTML; //圖片列表復(fù)制一份
oul.style.width=oli[0].offsetWidth*oli.length+'px'; //不算出ul的寬度的話,運(yùn)動過程中后面的會先出現(xiàn)再加載圖片,有一種不流暢感,切圖片過多會分行,由外面的div決定寬度
timer=setInterval(function(){
oul.style.left=oul.offsetLeft+ispeed+'px'; //offsetLeft輸出的是數(shù)字不帶單位,右邊也用oul.style.left輸出的是字符串,而不是數(shù)值,而且它取得是行間樣式,無用
if(oul.offsetLeft<-oul.offsetWidth/2){ //判斷時也可以用.style.left或.style.width?(不確定)
oul.style.left=0;
}
else if(oul.offsetLeft>0){
oul.style.left=-oul.offsetWidth/2;
}
),30};
btn[0].onmouseover=function(){
ispeed=-1;
};
btn[1].onmouseover=function(){
ispeed=1;
};
oul.onmouseover=function(){
clearInterval(timer);
};
oul.onmouseout=function(){
timer=setInterval(function(){
oul.style.left=oul.offsetLeft+ispeed+'px';
if(oul.offsetLeft<-oul.offsetWidth/2){
oul.style.left=0;
}
else if(oul.offsetLeft>0){
oul.style.left=-oul.offsetWidth/2;
}
),30}; //如果把速度變大,而定時器的時間也變大是否可以達(dá)到相同效果呢?答案是不能。會變成一卡一卡
};
};
注:這樣子取得的寬度是不包含margin的,所以圖片間邊距的寫法可以是li的寬度大于img的寬度,li的寬度-img的寬度,就是兩邊的邊距和
更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript切換特效與技巧總結(jié)》、《JavaScript查找算法技巧總結(jié)》、《JavaScript動畫特效與技巧匯總》、《JavaScript錯誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》
希望本文所述對大家JavaScript程序設(shè)計有所幫助。
- 簡單實現(xiàn)js間歇或無縫滾動效果
- js超時調(diào)用setTimeout和間歇調(diào)用setInterval實例分析
- javascript學(xué)習(xí)筆記(十五) js間歇調(diào)用和超時調(diào)用
- javascript動畫系列之模擬滾動條
- js實現(xiàn)頁面刷新滾動條位置不變
- JS實現(xiàn)的相冊圖片左右滾動完整實例
- JS實現(xiàn)判斷滾動條滾到頁面底部并執(zhí)行事件的方法
- js操作滾動條事件實例
- js判斷滾動條是否已到頁面最底部或頂部實例
- JS實現(xiàn)單行文字不間斷向上滾動的方法
- js網(wǎng)頁滾動條滾動事件實例分析
- JS實現(xiàn)間歇滾動的運(yùn)動效果實例
相關(guān)文章
IE圖片緩存document.execCommand("BackgroundImageCache",
IE6下設(shè)置背景圖片是不會被真正cache住的,就算服務(wù)器做了cache,如果想cache住只能2011-03-03
JavaScript棧和隊列相關(guān)操作與實現(xiàn)方法詳解
這篇文章主要介紹了JavaScript棧和隊列相關(guān)操作與實現(xiàn)方法,結(jié)合實例形式較為詳細(xì)的分析了javascript棧和隊列的概念、原理、定義、用法及相關(guān)操作注意事項,需要的朋友可以參考下2018-12-12
詳解js的事件處理函數(shù)和動態(tài)創(chuàng)建html標(biāo)記方法
本文主要對javascript的事件處理函數(shù),動態(tài)創(chuàng)建html標(biāo)記的兩種方法進(jìn)行詳細(xì)介紹,具有很好的參考價值,需要的朋友一起來看下吧2016-12-12

