DOM自学中的一个问题,求解答,谢谢

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);
为什么要用字符串的形式?
谢谢~

阅读 2.8k
6 个回答

setTimeout第一个参数可以是直接的函数变量,也可以是一个字符串,如果是字符串形式的话,在一定时间后就会直接执行之。
lz代码中的写法是正确的,虽然我并不推荐这么写。

var repeat = moveElement("elementID",final_x,final_y,interval);

这样会直接执行,没有延时。
其实比较推荐setTimeout(moveElement,interval, elementID, final_x, final_y, interval);的写法。

因为它们是形参不是实参

var repeat = "moveElement('"+elementID+"',"+final_x+","+final_y+","+interval+")";这种写法是要存储等号后面拼接出来的字符串,然后再下面setTimeout方法中传参。如果直接写成 var repeat = moveElement("elementID",final_x,final_y,interval);就是直接调用这个方法了,repeat等于的是方法返回的结果。

var repeat="moveElment..."这个变量是字符串,
如果写成var repeat=moveElment();这就是函数调用并赋值给变量repeat了。

var repeat = "moveElement('"+elementID+"',"+final_x+","+final_y+","+interval+")";

相当于定义。

var repeat = moveElement("elementID",final_x,final_y,interval);

相当于调用。

新手上路,请多包涵

请问为什么不能写成下面这种呢?

el.movement = setTimeout(function(){
    moveElement(el,final_x,final_y,interval)
  }, interval);
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题