if (demo2.offsetHeight - demo.scrollTop + 16<0)//当滚动至demo1与demo2交界时 ,
demo.scrollTop -= demo1.offsetHeight + 16//demo跳到最顶端
}16是谷歌浏览器下p标签默认的margin-top的值。
这样就不会有跳动了。
卡顿的问题有两个因素影响了,一个是:向左移动的速度必须为div宽度能整除的数,要不减到最后判断的时候会有余量。二个是:判断的时候已经到了边界了,所以应该执行下一次。修改的例子:
<!doctype html><html>
<head>
<meta charset="utf-8">
<title>无缝滚动</title>
<style type="text/css">
*{margin:0padding:0}
#div2{width:600pxoverflow:hiddenposition:relativeleft:200px}
#div1{position:relativeleft:0pxwidth:1200px}
#div1 li{list-style-type: nonefloat:leftwidth:200pxheight:180px
}
img{width:100%height:100%}
</style>
<script>
window.onload=function(){
var oUl=document.getElementById('ul1')
var oDiv=document.getElementById('div1')
var oBtn=document.getElementById('btn1')
var t=0
oUl.innerHTML = oUl.innerHTML + oUl.innerHTML
var speed = 20//速度,必须是oUl.offsetWidth能整除的数;
oBtn.onclick=function(){
clearInterval(t)
t=setInterval(function(){
if(oDiv.offsetLeft <= -oUl.offsetWidth/2){
oDiv.style.left = -speed+'px'//因为判断的时候已经到了边界了,所以应该执行下次
}else{
oDiv.style.left = oDiv.offsetLeft - speed+'px'
}
},50)
}
}
</script>
</head>
<body>
<input id="btn1" value="开始" type="button"/>
<div id="div2">
<div id="div1">
<ul id="ul1">
<li><img src="1.jpg"></li>
<li><img src="2.jpg"></li>
<li><img src="3.jpg"></li>
</ul>
</div>
</div>
</body>
</html>
这是最古老的js滚动代码了,人家的最初完成dome 是没问题的,估计的看到的是不知道转手多少次的了问题出在这
demo.scrollTop -= demo1.offsetHeight //demo跳到最顶端
在浏览器中 P有默认margin ; 但margin 高度不计算在 offsetHeight
<style>p{ margin:0px}</style>