您好,登錄后才能下訂單哦!
這篇文章主要介紹如何基于JavaScript實現無縫滾動效果,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
首先應該區分樣式中的絕對定位和相對定位,一般來說,移動的單位為絕對定位,在這個實例中,移動的Ul就是絕對定位 ,否則它根本無法滾動,而它相對于div1滾動 ,則div1就作為他的相對定位。
oUl.innerHTML=oUl.innerHTML+oUl.innerHTML;這段代碼是實現無縫滾動的核心,使之可以在不論左右滾動的時候都有下一步圖片接上去。
在操作或者進行比較的時候,都要用offset取值來進行操作或者比較!!!
代碼:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>無縫滾動2</title> <style type="text/css"> *{ padding: 0; margin:0; } #div1{ position: relative; width: 800px; height: 200px; background:red; margin:100px auto; overflow: hidden; } #div1 ul{ position: absolute; left: 0; top: 0; } #div1 ul li{ float: left; list-style: none; width: 200px; height: 200px; } </style> <script type="text/javascript"> window.onload=function() { var oDiv = document.getElementById('div1'); var oUl = oDiv.getElementsByTagName('ul')[0]; var aLi = oDiv.getElementsByTagName('li'); var aA = document.getElementsByTagName('a'); var speed = 3; oUl.innerHTML=oUl.innerHTML+oUl.innerHTML; oUl.style.width=aLi.length*aLi[0].offsetWidth+'px'; var timer=setInterval(move,30); function move() { if (oUl.offsetLeft<=-oUl.offsetWidth/2) { oUl.style.left="0"; } if(oUl.offsetLeft>0){ oUl.style.left=-oUl.offsetWidth/2+'px'; } oUl.style.left=oUl.offsetLeft+speed+'px'; }; oDiv.onmouseover=function() { clearInterval(timer); }; oDiv.onmouseout=function() { timer=setInterval(move,30); }; aA[0].onclick=function() { speed=-3; }; aA[1].onclick=function() { speed=3; }; }; </script> </head> <body> <a href="javascript:;">向左</a> <a href="javascript:;">向右</a> <div id="div1"> <ul> <li><img src="images/n1.jpg"></li> <li><img src="images/n2.jpg"></li> <li><img src="images/n3.jpg"></li> <li><img src="images/n4.jpg"></li> </ul> </div> </body> </html>
以上是“如何基于JavaScript實現無縫滾動效果”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。