效果:

思路:

首先,加载onscroll控制滚动条。然后写缓存运动的方法,缓冲运动的方法是先计算出DIV缓冲的速度,并且将其取整,再进行运动判断什么时候到达终点。最后将其参数返回。再在onscroll里面调用此方法,并且将终点计算出来赋予此方法的参数。

代码:

 <head runat="server">
<title></title>
<style type="text/css">
#div1
{
width: 200px;
height: 200px;
background: #0000FF;
position: absolute;
right: 0;
bottom: 0;
}
</style>
<script type="text/javascript">
window.onscroll = function () {
var oDiv = document.getElementById('div1');
var DivScroll = document.documentElement.scrollTop || document.body.scrollTop; //获取移动高度
// oDiv.style.top = (document.documentElement.clientHeight - oDiv.offsetHeight)/2 + DivScroll + 'px';
move(parseInt((document.documentElement.clientHeight - oDiv.offsetHeight) / 2 + DivScroll)); //调用传参,其中里面的参数是DIV要走的终点。也就是(可视高度-DIV高度)/2+移动高度
}; var timer = null;
function move(end) {
clearInterval(timer); //首先,先关闭之前如果有开启的setInterval;
timer = setInterval(function () {
var oDiv = document.getElementById('div1');
var speed = (end - oDiv.offsetTop) / 5; //计算DIV要走的速度,DIV要走的速度就等于(终点-offsetTop高度)/缩放系数
speed = speed > 0 ? Math.ceil(speed) : Math.floor(speed); //为了避免小数,将其取整
if (oDiv.offsetTop == end) { //当DIV到达终点,则关闭setInterval;
clearInterval(timer);
}
else {
oDiv.style.top = oDiv.offsetTop + speed + 'px'; //移动div
}
}, 30);
}
</script>
</head>
<body style="height: 1000px;">
<div id="div1">
</div>
</body>

最新文章

  1. 设计模式(十一)外观模式(Facade Pattern)
  2. Html概要及示例(一)
  3. Objective-C 高性能的循环
  4. React同构直出原理浅析
  5. Android intent传递list或对象
  6. linux嵌入式系统驱动程序的阻塞与异步
  7. Android(java)学习笔记249:ContentProvider使用之获得系统联系人信息01
  8. tr 替换删除字符
  9. #include &lt;stdint.h&gt;
  10. 使用gson和httpclient呼叫微信公众平台API
  11. 使用hibernate在5秒内插入11万条数据,你觉得可能吗?
  12. EntityFramework Core Raw Query再叙注意事项
  13. 如何使用jconsole(英文)
  14. Spring MVC (JDK8+Tomcat8)
  15. WebApi 方法的参数类型总结。
  16. 【转】Android 之最新最全的Intent传递数据方法
  17. bzoj1206-[HNOI2005]虚拟内存
  18. 如何让eclipse恢复默认布局
  19. 6、GNU makefile工程管理学习的一个例子
  20. 我的Eclipse设置

热门文章

  1. FIS常用功能之资源合并
  2. CSS -- 绝对相对定位
  3. mybatis批量操作-xml方式
  4. EasyUI datagrid 双击行事件
  5. REDIS数据备份集群部署和双集群同步工具redis-migrate-tool
  6. Spring与Quartz的整合
  7. 创建CrawlSpider爬虫简要步骤
  8. ZOJ3622 Magic Number(水题)
  9. MR 数据过滤
  10. 2018.1.9 博客迁移至csdn