無縫滾動(dòng)的簡(jiǎn)單實(shí)現(xiàn)代碼(推薦)
原理:
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>
如有錯(cuò)誤,歡迎指正。
以上這篇無縫滾動(dòng)的簡(jiǎn)單實(shí)現(xiàn)代碼(推薦)就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
JavaScript簡(jiǎn)單獲取頁面圖片原始尺寸的方法
這篇文章主要介紹了JavaScript簡(jiǎn)單獲取頁面圖片原始尺寸的方法,可通過Image()對(duì)象直接獲取圖片的原始寬高,簡(jiǎn)單實(shí)用,需要的朋友可以參考下2016-06-06
Flutter實(shí)現(xiàn)仿微信底部菜單欄功能
這篇文章主要介紹了Flutter實(shí)現(xiàn)仿微信底部菜單欄,需要的朋友可以參考下2019-09-09
js實(shí)現(xiàn)帶圓角的兩級(jí)導(dǎo)航菜單效果代碼
這篇文章主要介紹了js實(shí)現(xiàn)帶圓角的兩級(jí)導(dǎo)航菜單效果代碼,涉及javascript鼠標(biāo)事件及頁面元素樣式動(dòng)態(tài)變換技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-08-08
JavaScript實(shí)現(xiàn)彈出子窗口并傳值給父窗口
這篇文章主要介紹了JavaScript實(shí)現(xiàn)彈出子窗口并傳值給父窗口,方法很簡(jiǎn)單,這里推薦給大家,需要的朋友可以參考下2014-12-12
D3.js實(shí)現(xiàn)散點(diǎn)圖和氣泡圖的方法詳解
這篇文章將會(huì)給大家介紹了另外兩種可視化圖表,利用D3.js實(shí)現(xiàn)散點(diǎn)圖和氣泡圖,文章通過多個(gè)方面介紹的非常詳細(xì),下面來一起看看吧。2016-09-09
JavaScript中new操作符的原理與實(shí)現(xiàn)詳解
你知道new嗎?你知道new的實(shí)現(xiàn)原理嗎?你能手寫new方法嗎?不要擔(dān)心,這篇文件就來帶大家深入了解一下JavaScript中的new操作符,感興趣的小伙伴可以學(xué)習(xí)一下2022-10-10
javascript實(shí)現(xiàn)掃雷簡(jiǎn)易版
這篇文章主要為大家詳細(xì)介紹了javascript實(shí)現(xiàn)掃雷簡(jiǎn)易版,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-08-08

