이 기사에서는 모든 사람에게 도움이 되기를 바라며 JS의 원활한 스크롤에 대한 예를 주로 공유합니다. 효과 원리: ul을 계속 왼쪽으로 스크롤하도록 합니다. li를 복사하고 ul의 너비를 변경하고 범위를 벗어났는지 판단합니다. 왼쪽이나 오른쪽으로 제어하고, 속도를 설정하고, 양수 또는 음수 값을 변경하세요.
<!DOCTYPE html><html> <head> <meta charset="UTF-8"> <title>无缝轮播</title> <style> *{margin: 0;padding: 0;} #p1{width: 800px;height: 150px;margin: 100px auto;position: relative;background: blue;overflow: hidden;} #p1 ul{position: absolute;top: 0;left: 0;} #p1 ul li{list-style-type: none;float: left;width: 200px;height: 150px;;} img{width: 200px;height: 150px;} </style> <script> window.onload=function(){ //控制向左向右,主要是通过是加还是减speed var speed=-2; function move(){ if(oUl.offsetLeft<-oUl.offsetWidth/2){ //当其往左移动了四个li的宽度时,把整个图片拉回来 oUl.style.left=0; } if(oUl.offsetLeft>0){ //记得末尾加px oUl.style.left=-oUl.offsetWidth/2+'px'; } oUl.style.left=oUl.offsetLeft+speed+'px'; }; var time=null; var op = document.getElementById('p1'); var oUl = op.getElementsByTagName('ul')[0]; var oLi = op.getElementsByTagName('li'); //使其形成8个li oUl.innerHTML = oUl.innerHTML+oUl.innerHTML; oUl.style.width = oLi[0].offsetWidth*oLi.length+'px'; time = setInterval(move,30); op.onmouseover= function(){ clearInterval(time); } op.onmouseout= function(){ time = setInterval(move,30); } var oBtn = document.getElementsByTagName('button'); oBtn[0].onclick = function(){ speed = -2; } oBtn[1].onclick = function(){ speed = 2; } } </script> </head> <body> <button value="向左走">向左走</button> <button value="向右走">向右走</button> <p id="p1"> <ul> <li><img src="img/1.jpg"></li> <li><img src="img/3.jpg"></li> <li><img src="img/4.jpg"></li> <li><img src="img/2.jpg"></li> </ul> </p> </body></html>
관련 추천:
JS 원활한 스크롤 코드_javascript 기술에 대한 포괄적인 이해
js에서 텍스트 목록의 원활한 스크롤을 달성하는 방법은 무엇입니까?
위 내용은 js 원활한 스크롤 공유 예의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!