function moveElement( elementID , final_x , final_y, interval ) {
if ( !document.getElementById ) return false;
if ( !document.getElementById(elementID) ) return false;
var elem = document.getElementById(elementID);
var xpos = parseInt(elem.style.left);
var ypos = parseInt(elem.style.top);
if (xpos == final_x && ypos == final_y) {
}
if (xpos < final_x) {
xpos++;
}
if (xpos > final_x) {
xpos--;
}
if (ypos < final_y) {
ypos++;
}
if (ypos > final_y) {
ypos--;
}
elem.style.left = xpos + "px";
elem.style.top = ypos + "px";
var repeat = "moveElement('"+elementID+"',"+final_x+","+final_y+","+interval+")";
movement = setTimeout(repeat,interval);
}
其中:var repeat = "moveElement('"+elementID+"',"+final_x+","+final_y+","+interval+")";
的+elementID+前面的加号和+interval+后面的加号的作用是什么呢?
加号是字符串拼接用的。
var repeat = "moveElement('" + elementID + "'," + final_x + "," + final_y + "," + interval + ")";
这样看起来好看一点吧,双引号中间的是字符串,加号把字符串跟变量拼接起来。
这就是在拼接字符串
例如
var a = 1;
var b = 2;
var str = 'a is' + a + ' , b is' + b;
此时 str -> 'a is1 , b is2'
需要注意点的就是 setTimeout 函数调用时,第一个参数是 字符串, 会转成 js 表达式
就是把函数上的那些参数放进去,不加 + 号会被当成字符串的
这段代码中的
moveElement
是循环非阻塞调用的。那句话的意思是拼成一个函数调用表达式,然后放进
setTimeout
里面执行。但不推荐这么写,可以写成
moveElement.bind(null, elementID, final_x, final_y, interval)
。