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+后面的加号的作用是什么呢?
付费偷看金额在0.1-10元之间
这就是在拼接字符串
这段代码中的
moveElement
是循环非阻塞调用的。此时 str -> a is1 , b is2
var str = a is + a + , b is + b;
加号是字符串拼接用的。
var repeat = "moveElement(" + elementID + "," + final_x + "," + final_y + "," + interval + ")";
这样看起来好看一点吧,双引号中间的是字符串,加号把字符串跟变量拼接起来。
那句话的意思是拼成一个函数调用表达式,然后放进
setTimeout
里面执行。var a = 1;
var b = 2;
但不推荐这么写,可以写成
moveElement.bind(null, elementID, final_x, final_y, interval)
。需要注意点的就是 setTimeout 函数调用时,第一个参数是 字符串, 会转成 js 表达式
例如
一周热门 更多>