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>    

效果