基于JS實(shí)現(xiàn)無縫滾動(dòng)思路及代碼分享
原理:
1.給ul一個(gè)絕對(duì)定位使其脫離文檔流,left設(shè)置為0,把圖片塞進(jìn)ul里,編寫一個(gè)“移動(dòng)"函數(shù),函數(shù)功能能夠使ul的left以一個(gè)正速度向右跑動(dòng),
2.設(shè)置一個(gè)定時(shí)器,讓"移動(dòng)"函數(shù)每30(參數(shù)可變)毫秒執(zhí)行一次
3.因?yàn)閡l的長(zhǎng)度會(huì)“跑”完,此時(shí)可以使ul的content也就是img增加一倍,
oUl.innerHTML +=oUl.innerHTML;
4.此時(shí)因?yàn)閡l的content增加,其width也會(huì)隨著增大,根據(jù)實(shí)際項(xiàng)目展示圖片數(shù)量可能改動(dòng)或不確定性,
oUl.style.width = oLi.length*oLi[0].offsetWidth+'px';
5.往“移動(dòng)”函數(shù)里增添代碼。
5.1此時(shí)ul向右移動(dòng),判斷當(dāng)ul的offsetLeft>0時(shí),把ul向左拉“一半ul的寬度”,也就是使ul能夠向右一直無限制移動(dòng)
if(oUl.offsetLeft>0){
oUl.style.left = -oUl.offsetWidth/2+'px';
}
5.2當(dāng)ul向左移動(dòng),其offsetLeft跑了ul一半的寬度時(shí),把整個(gè)ul拉回至初始的left:0;
if (oUl.offsetLeft<-oUl.offsetWidth/2) {
oUl.style.left = 0;
}
上代碼:
html:
<div id="box"> <ul> <li><a href="#"><img src="1.jpg" /></a></li> <li><a href="#"><img src="2.jpg" /></a></li> <li><a href="#"><img src="3.jpg" /></a></li> <li><a href="#"><img src="4.jpg" /></a></li> </ul> </div>
css:
* {margin: 0;padding: 0;}
#box{ width: 480px; height: 110px; border: 1px red solid; margin: 100px auto;overflow: hidden; position: relative; }
#box ul{ position: absolute; left: 0; top: 5px;}
#box ul li{list-style: none; float: left; width: 100px; height: 100px; padding-left: 16px; }
#box ul li img{width: 100px; height: 100px;}
js:
<script>
window.onload = function(){
var oDiv = document.getElementById('div1');
var oUl = oDiv.getElementsByTagName('ul')[0];
var oLi = oUl.getElementsByTagName('li');
var aA = document.getElementsByTagName('a');
var iSpeed = 10; //讓ul開始就具有一個(gè)速度走動(dòng)
oUl.innerHTML +=oUl.innerHTML;
oUl.style.width = oLi.length*oLi[0].offsetWidth+'px';
aA[0].onclick = function(){
iSpeed = -10;
};
aA[1].onclick = function(){
iSpeed = 10;
};
function fnMove(){
if (oUl.offsetLeft<-oUl.offsetWidth/2) { //負(fù)數(shù)是因?yàn)閡l的left是負(fù)數(shù) oUl.style.left = 0;
}
else if(oUl.offsetLeft>0){ oUl.style.left = -oUl.offsetWidth/2+'px';
}
oUl.style.left = oUl.offsetLeft+iSpeed+'px'; //整個(gè)ul向右移動(dòng)
};
var timer = null;
clearInterval(timer);
timer = setInterval(fnMove,30);
oUl.onmouseover = function(){
clearInterval(timer);
};
oUl.onmouseout = function(){
timer = setInterval(fnMove,30); //當(dāng)鼠標(biāo)移開的時(shí)候執(zhí)行這個(gè)定時(shí)器
};
};
</script>
以上所述是小編給大家分享的基于JS實(shí)現(xiàn)無縫滾動(dòng)思路及代碼,希望能夠幫助到大家,如果大家有任何疑問歡迎給我留言,小編會(huì)及時(shí)回復(fù)大家的,在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
Kotlin學(xué)習(xí)第一步 kotlin語(yǔ)法特性
Kotlin學(xué)習(xí)第一步,從kotlin語(yǔ)法特性開始學(xué)習(xí),包括變量定義、函數(shù)擴(kuò)展、Parcelable序列化、編寫工具類等,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-05-05
js關(guān)閉當(dāng)前頁(yè)面(窗口)的幾種方式總結(jié)
js關(guān)閉當(dāng)前頁(yè)面(窗口)的幾種方式總結(jié),需要的朋友可以參考一下2013-03-03
Javascript中的函數(shù)聲明與函數(shù)表達(dá)式(奇技淫巧)
Javascript有很多有趣的用法,在Google Code Search里能找到不少,今天從火丁筆記看到的,非常不錯(cuò),推薦大家看下。2011-03-03
js通過八個(gè)點(diǎn) 拖動(dòng)改變div大小的實(shí)現(xiàn)方法
本篇文章主要是對(duì)js通過八個(gè)點(diǎn) 拖動(dòng)改變div大小的實(shí)現(xiàn)方法進(jìn)行了介紹,需要的朋友可以過來參考下,希望對(duì)大家有所幫助2014-03-03
videojs+swiper實(shí)現(xiàn)淘寶商品詳情輪播圖
這篇文章主要為大家詳細(xì)介紹了videojs+swiper實(shí)現(xiàn)淘寶商品詳情輪播圖,輪播翻動(dòng),視頻暫停,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-04-04

