javascript - DOM编程艺术中的小问题,不是特别理解,求解答
黄舟
黄舟 2017-04-11 13:20:44
[JavaScript讨论组]
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+后面的加号的作用是什么呢?

黄舟
黄舟

人生最曼妙的风景,竟是内心的淡定与从容!

全部回复(4)
伊谢尔伦

加号是字符串拼接用的。
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)

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号