JavaScript动画函数
来源:互联网 发布:莞城金域名苑怎么样 编辑:程序博客网 时间:2024/06/05 03:03
本例介绍了一个应用比较灵活的移动动画函数,使用它来移动网页中指定id的元素。
实例JavaScript代码
本例的代码摘自《JavaScript DOM编程艺术》一书。是一个可以拿来就用的HTML元素移动函数。使用方法如下:给函数传递元素的id,目的位置,以及延时间隔(控制速度)。
<script type="text/javascript">function moveElement(elementID,final_x,final_y,interval) { if (!document.getElementById) return false; if (!document.getElementById(elementID)) return false; var elem = document.getElementById(elementID); if (elem.movement) { clearTimeout(elem.movement); } if (!elem.style.left) { elem.style.left = "0px"; } if (!elem.style.top) { elem.style.top = "0px"; } var xpos = parseInt(elem.style.left); var ypos = parseInt(elem.style.top); if (xpos == final_x && ypos == final_y) { return true; } if (xpos < final_x) { var dist = Math.ceil((final_x - xpos)/10); xpos = xpos + dist; } if (xpos > final_x) { var dist = Math.ceil((xpos - final_x)/10); xpos = xpos - dist; } if (ypos < final_y) { var dist = Math.ceil((final_y - ypos)/10); ypos = ypos + dist; } if (ypos > final_y) { var dist = Math.ceil((ypos - final_y)/10); ypos = ypos - dist; } elem.style.left = xpos + "px"; elem.style.top = ypos + "px"; var repeat = "moveElement('"+elementID+"',"+final_x+","+final_y+","+interval+")"; elem.movement = setTimeout(repeat,interval);}function test(){ var elem = document.getElementById("content"); elem.style.position = "relative"; elem.style.left = "0px"; elem.style.top = "0px"; moveElement("content",50,50,20);}</script>
HTML代码
本例只有一个调用函数的按钮。
<button onclick="test(); return false;" value="改变位置" >开始测试</button>
效果
- JavaScript动画函数
- javascript 自定义动画函数
- javascript通用动画函数
- JavaScript封装缓动动画函数
- javascript动画
- JavaScript 动画
- JavaScript 动画
- JavaScript动画
- JavaScript动画
- JavaScript动画
- JavaScript动画1-速度动画
- javascript 弹出动画对话框
- JavaScript 动画(三十六)
- javascript流畅动画
- JavaScript 闭包动画
- javascript控制flash动画
- JavaScript动画基础知识
- JAVASCRIPT动画之一
- SIM卡在手机中的主要作用
- mysqldump 导出数据和存储过程
- Scrapy入门教程
- Wireshark介绍
- ASP.NET MVC案例教程(基于ASP.NET MVC beta)——第四篇:传递表单数据
- JavaScript动画函数
- 一步一步复习数据结构和算法基础-中序线索二叉树
- 智能卡行业的产业链
- 利用硬件Blitter实现表面间位图复制
- java对字符的编码处理
- POJ-3468-A Simple Problem with Integers
- oracle静态监听和动态监听
- 拓扑排序(谢庆皇)
- Com组件和一般DLL的区别