效果: 思路: 首先,加载onscroll控制滚动条。然后写缓存运动的方法,缓冲运动的方法是先计算出DIV缓冲的速度,并且将其取整,再进行运动判断什么时候到达终点。最后将其参数返回。再在onscroll里面调用此方法,并且将终点计算出来赋予此方法的参数。 代码: 复制代码 代码如下: <BR> #div1<BR> {<BR> width: 200px;<BR> height: 200px;<BR> background: #0000FF;<BR> position: absolute;<BR> right: 0;<BR> bottom: 0;<BR> }<BR> <BR> window.onscroll = function () {<BR> var oDiv = document.getElementById('div1');<BR> var DivScroll = document.documentElement.scrollTop || document.body.scrollTop; //获取移动高度<BR> // oDiv.style.top = (document.documentElement.clientHeight - oDiv.offsetHeight)/2 + DivScroll + 'px';<BR> move(parseInt((document.documentElement.clientHeight - oDiv.offsetHeight) / 2 + DivScroll)); //调用传参,其中里面的参数是DIV要走的终点。也就是(可视高度-DIV高度)/2+移动高度<BR> }; <P> var timer = null;<BR> function move(end) {<BR> clearInterval(timer); //首先,先关闭之前如果有开启的setInterval;<BR> timer = setInterval(function () { <BR> var oDiv = document.getElementById('div1');<BR> var speed = (end - oDiv.offsetTop) / 5; //计算DIV要走的速度,DIV要走的速度就等于(终点-offsetTop高度)/缩放系数<BR> speed = speed > 0 ? Math.ceil(speed) : Math.floor(speed); //为了避免小数,将其取整<BR> if (oDiv.offsetTop == end) { //当DIV到达终点,则关闭setInterval;<BR> clearInterval(timer);<BR> }<BR> else {<BR> oDiv.style.top = oDiv.offsetTop + speed + 'px'; //移动div<BR> }<BR> }, 30);<BR> }<BR>