JS無縫滾動效果實(shí)現(xiàn)方法分析
本文實(shí)例講述了JS無縫滾動效果實(shí)現(xiàn)方法。分享給大家供大家參考,具體如下:
效果:
1.默認(rèn)緩慢往左滾動
2.放到左箭頭上還是向左滾動,放到右箭頭上向右滾動
3.放到圖片上停止?jié)L動,移出繼續(xù)滾動
思路:
1.計(jì)算圖片列表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è)計(jì)有所幫助。
- 簡單實(shí)現(xiàn)js間歇或無縫滾動效果
- js超時調(diào)用setTimeout和間歇調(diào)用setInterval實(shí)例分析
- javascript學(xué)習(xí)筆記(十五) js間歇調(diào)用和超時調(diào)用
- javascript動畫系列之模擬滾動條
- js實(shí)現(xiàn)頁面刷新滾動條位置不變
- JS實(shí)現(xiàn)的相冊圖片左右滾動完整實(shí)例
- JS實(shí)現(xiàn)判斷滾動條滾到頁面底部并執(zhí)行事件的方法
- js操作滾動條事件實(shí)例
- js判斷滾動條是否已到頁面最底部或頂部實(shí)例
- JS實(shí)現(xiàn)單行文字不間斷向上滾動的方法
- js網(wǎng)頁滾動條滾動事件實(shí)例分析
- JS實(shí)現(xiàn)間歇滾動的運(yùn)動效果實(shí)例
相關(guān)文章
純JS實(shí)現(xiàn)表單驗(yàn)證實(shí)例
這篇文章主要介紹了純JS實(shí)現(xiàn)表單驗(yàn)證實(shí)例,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2016-12-12IE圖片緩存document.execCommand("BackgroundImageCache",
IE6下設(shè)置背景圖片是不會被真正cache住的,就算服務(wù)器做了cache,如果想cache住只能2011-03-03css 二級菜單 實(shí)現(xiàn)代碼集合 修正版
最近的網(wǎng)站要求使用二級菜單,本著“能用別人的就用別人的,不能用別人的就用自己的”的原則,在網(wǎng)上找到一個經(jīng)典的使用CSS制作的二級菜單,感覺不錯,先記錄下來,以備它用。2009-06-06JavaScript棧和隊(duì)列相關(guān)操作與實(shí)現(xiàn)方法詳解
這篇文章主要介紹了JavaScript棧和隊(duì)列相關(guān)操作與實(shí)現(xiàn)方法,結(jié)合實(shí)例形式較為詳細(xì)的分析了javascript棧和隊(duì)列的概念、原理、定義、用法及相關(guān)操作注意事項(xiàng),需要的朋友可以參考下2018-12-12javascript中的深復(fù)制詳解及實(shí)例分析
這篇文章主要介紹了javascript中的深復(fù)制詳解及實(shí)例分析的相關(guān)資料,需要的朋友可以參考下2016-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