JS無(wú)縫滾動(dòng)效果實(shí)現(xiàn)方法分析
本文實(shí)例講述了JS無(wú)縫滾動(dòng)效果實(shí)現(xiàn)方法。分享給大家供大家參考,具體如下:
效果:
1.默認(rèn)緩慢往左滾動(dòng)
2.放到左箭頭上還是向左滾動(dòng),放到右箭頭上向右滾動(dòng)
3.放到圖片上停止?jié)L動(dòng),移出繼續(xù)滾動(dòng)
思路:
1.計(jì)算圖片列表ul的寬度
2.開啟定時(shí)器,使其向左邊距不斷增大,造成向左運(yùn)動(dòng)的效果
3.圖片列表復(fù)制一份,向左移動(dòng)時(shí),當(dāng)左邊距大于一份的寬度時(shí),把它的左邊距拉回到0。向右移動(dòng)時(shí),當(dāng)左邊距大于0時(shí),把它的左邊距拉到整個(gè)兩份圖片列表一半的寬度(即一份的寬度)。(拉的瞬間很快,用戶察覺(jué)不到,造成一種無(wú)縫滾動(dòng)的假象)
4.offsetLeft值的正負(fù)決定往哪邊移動(dòng)
5.放到圖片上停止這個(gè)定時(shí)器,移開再開啟
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)動(dòng)過(guò)程中后面的會(huì)先出現(xiàn)再加載圖片,有一種不流暢感,切圖片過(guò)多會(huì)分行,由外面的div決定寬度 timer=setInterval(function(){ oul.style.left=oul.offsetLeft+ispeed+'px'; //offsetLeft輸出的是數(shù)字不帶單位,右邊也用oul.style.left輸出的是字符串,而不是數(shù)值,而且它取得是行間樣式,無(wú)用 if(oul.offsetLeft<-oul.offsetWidth/2){ //判斷時(shí)也可以用.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}; //如果把速度變大,而定時(shí)器的時(shí)間也變大是否可以達(dá)到相同效果呢?答案是不能。會(huì)變成一卡一卡 }; };
注:這樣子取得的寬度是不包含margin的,所以圖片間邊距的寫法可以是li的寬度大于img的寬度,li的寬度-img的寬度,就是兩邊的邊距和
更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript切換特效與技巧總結(jié)》、《JavaScript查找算法技巧總結(jié)》、《JavaScript動(dòng)畫特效與技巧匯總》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》
希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。
- 簡(jiǎn)單實(shí)現(xiàn)js間歇或無(wú)縫滾動(dòng)效果
- js超時(shí)調(diào)用setTimeout和間歇調(diào)用setInterval實(shí)例分析
- javascript學(xué)習(xí)筆記(十五) js間歇調(diào)用和超時(shí)調(diào)用
- javascript動(dòng)畫系列之模擬滾動(dòng)條
- js實(shí)現(xiàn)頁(yè)面刷新滾動(dòng)條位置不變
- JS實(shí)現(xiàn)的相冊(cè)圖片左右滾動(dòng)完整實(shí)例
- JS實(shí)現(xiàn)判斷滾動(dòng)條滾到頁(yè)面底部并執(zhí)行事件的方法
- js操作滾動(dòng)條事件實(shí)例
- js判斷滾動(dòng)條是否已到頁(yè)面最底部或頂部實(shí)例
- JS實(shí)現(xiàn)單行文字不間斷向上滾動(dòng)的方法
- js網(wǎng)頁(yè)滾動(dòng)條滾動(dòng)事件實(shí)例分析
- JS實(shí)現(xiàn)間歇滾動(dòng)的運(yùn)動(dòng)效果實(shí)例
相關(guān)文章
純JS實(shí)現(xiàn)表單驗(yàn)證實(shí)例
這篇文章主要介紹了純JS實(shí)現(xiàn)表單驗(yàn)證實(shí)例,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-12-12IE圖片緩存document.execCommand("BackgroundImageCache",
IE6下設(shè)置背景圖片是不會(huì)被真正cache住的,就算服務(wù)器做了cache,如果想cache住只能2011-03-03簡(jiǎn)單實(shí)現(xiàn)js懸浮導(dǎo)航效果
這篇文章主要教大家如何簡(jiǎn)單實(shí)現(xiàn)js懸浮導(dǎo)航效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-02-02JavaScript使用cookie記錄臨時(shí)訪客信息的方法
這篇文章主要介紹了JavaScript使用cookie記錄臨時(shí)訪客信息的方法,涉及javascript操作cookie的技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-04-04css 二級(jí)菜單 實(shí)現(xiàn)代碼集合 修正版
最近的網(wǎng)站要求使用二級(jí)菜單,本著“能用別人的就用別人的,不能用別人的就用自己的”的原則,在網(wǎng)上找到一個(gè)經(jīng)典的使用CSS制作的二級(jí)菜單,感覺(jué)不錯(cuò),先記錄下來(lái),以備它用。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ù)和動(dòng)態(tài)創(chuàng)建html標(biāo)記方法
本文主要對(duì)javascript的事件處理函數(shù),動(dòng)態(tài)創(chuàng)建html標(biāo)記的兩種方法進(jìn)行詳細(xì)介紹,具有很好的參考價(jià)值,需要的朋友一起來(lái)看下吧2016-12-12通過(guò)網(wǎng)頁(yè)查看JS源碼中漢字顯示亂碼的解決方法
這篇文章給大家主要介紹了通過(guò)網(wǎng)頁(yè)查看JS源碼的時(shí)候,發(fā)現(xiàn)漢字顯示是亂碼的解決方法,文中通過(guò)圖文詳解的介紹了解決的步驟,詳細(xì)會(huì)對(duì)大家很有幫助,有需要的朋友們下面來(lái)一起看看吧。2016-10-10