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);
var dist = 0;
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);
}
请问这行代码 var repeat = "moveElement('"+elementID+"',"+final_x+","+final_y+","+interval+")";
为什么不直接写成 var repeat = moveElement("elementID",final_x,final_y,interval);
为什么要用字符串的形式?
谢谢~
setTimeout第一个参数可以是直接的函数变量,也可以是一个字符串,如果是字符串形式的话,在一定时间后就会直接执行之。
lz代码中的写法是正确的,虽然我并不推荐这么写。
这样会直接执行,没有延时。
其实比较推荐
setTimeout(moveElement,interval, elementID, final_x, final_y, interval);
的写法。