我一直有一个地方不是很理解,这次看到一段代码很能说明问题:function moveElement (elementID, final_x, final_y, interval) {
var elem = document.getElementById(elementID);
var xpos = parseInt(elem.style.left);
var ypos = parseInt(elem.style.top);
......
var repeat = "moveElement('"+ elementID +"',"+ final_x +","+ final_y +","+ interval +")";
movement = setTimeout(repeat, interval)
}
我的疑问只有一个地方:    var repeat = "moveElement('"+ elementID +"',"+ final_x +","+ final_y +","+ interval +")";
    
在这一段里,elementID,final_x,final_y,interval四个是传入的参数,除了第一个是字符串,后面三个都是数字。我第一个不能理解的地方是这些参数为什么要加引号,第二个不能理解的是这里的加号有什么作用么。还有一个问题是像`elementID`这个字符串,为什么包了两层引号,在什么情况下需要这么做?加号一般我认为适用于字符串拼接,但在这里显然不是这样,一对引号就是一个独立的空间,加号包裹在这里面有什么意义么。

解决方案 »

  1.   

    http://ask.csdn.net/questions/384738
      

  2.   

    你把 repeat 打印出来就知道了
      

  3.   

    setTimeout   的第一个参数是调用该函数后要执行的JavaScript代码串,repeat就是一个代码串
      

  4.   

    repeat是在拼接字符串啊。
    大引号是在拼接字符串,小引号是参数(你的函数moveElement里面的str类型的参数要用引号括起来,不然JS会以为这是个变量,而你大引号已经在外面用了,所以只能用小引号)。repeat是作为一个function传到setTimeout里的
      

  5.   

    function moveElement (elementID, final_x, final_y, interval) {
        var elem = document.getElementById(elementID);
        var xpos = parseInt(elem.style.left);
        var ypos = parseInt(elem.style.top);
        ......
        //var repeat = "moveElement('"+ elementID +"',"+ final_x +","+ final_y +","+ interval +")";
        //movement = setTimeout(repeat, interval)
        movement = setTimeout(function(){moveElement(elementID,final_x,final_y,interval);},interval);
    }