效果 : 鼠标移入图片 停止滚动, 鼠标移出自动滚动
可以调整向左或右方向滚动
以上是一个简单的布局,下面是主要的Javascript 代码
立即学习“Java免费学习笔记(深入)”;
<script type="text/<a style=" color: text-decoration:underline title="javascript" href="https://www.php.cn/zt/15724.html" target="_blank">javascript"><br> window.onload = function() {<br> var oDiv = document.getElementById("div1");<br> var oUl = oDiv.getElementsByTagName('ul')[0];<br> var aLi = oUl.getElementsByTagName('li');<br> var speed = 2; <br> oUl.innerHTML += oUl.innerHTML;<br> oUl.style.width = aLi[0].offsetWidth * aLi.length + 'px';<br> function move() {<br> if (oUl.offsetLeft < -oUl.offsetWidth / 2) {<br> oUl.style.left = '0';<br> }<br> if (oUl.offsetLeft > 0) {<br> oUl.style.left = -oUl.offsetWidth / 2 + 'px';<br> }<br> oUl.style.left = oUl.offsetLeft + speed + 'px';<br> }<br> var timer = setInterval(move, 30);<br> oDiv.onmouseover = function() {<br> clearInterval(timer);<br> };<br> oDiv.onmouseout = function() {<br> timer = setInterval(move, 30);<br> };<br> document.getElementsByTagName('a')[0].onclick = function() {<br> speed = -2;<br> };<br> document.getElementsByTagName('a')[1].onclick = function() {<br> speed = 2;<br> };<br> }<br> </script>
简单讲下思路:
首先设置ul 里面的图片一共有8张 oUl.innerHTML += oUl.innerHTML;
在 计算ul的宽度为 li的实际宽度*8
之后将 多余的内容隐藏
注意 : oUl.offsetLeft 肯定是负值
所以判断的时候不要把负号漏掉
if (oUl.offsetLeft oUl.style.left = '0';
}
这段表示 图片滚动到一半了,迅速把图片拉回来,因为程序执行的太快,所以几乎看不出来 实现无缝滚动
最后使用 变量 speed 来控制左右方向的滚动。
以上代码只是实现了最基本的功能,小伙伴们可以在此基础上继续完善。















