肖然的爱great 2014-11-29 00:39 采纳率: 50%
浏览 1512

javascript 作用域问题

下面的代码为什么不能是图片移动,alert(wg_left)他的值已经变了,为啥图片不动呢,还有就是如果将
var wg_left=$('wg').style.left;放到move函数的上面,为何这个全局变量在move函数中用不呢,但是如果不获取图片的属性值,而是换个变量值,这个全局变量就能用,感到很郁闷?
代码如下:
<br> function $(id)<br> {<br> return document.getElementById(id);<br> }</p> <p>function move(e)<br> { var wg_left=$(&#39;wg&#39;).style.left;<br> wg_left=parseInt(wg_left.substr(wg_left.lenght-2));<br> switch(e.keyCode)<br> {<br> case 37:<br> alert(wg_left);<br> wg_left=wg_left-10+&quot;px&quot;;<br> alert(wg_left);<br> break;<br> }<br> }</p> <p>

  • 写回答

1条回答

  • Go 旅城通票 2014-11-29 06:03
    关注

    你只是改变了变量值,没有重新设置对象的left啊,这个值不是地址引用,是值引用,还学要重设下

    而且substr放你也用的不对,直接parseInt就行,不需要截取了,parseInt会将前面的数字字符串转为数字,碰到第一个非数字的内容之后的全部丢弃。而且需要注意设置left属性值你这个对象定位需要为absolute或者relative,要不设置left无效

    function $(id) { return document.getElementById(id); }
    function move(e) {
      var wg_left=$('wg').style.left; 
      wg_left=parseInt(wg_left);
      switch(e.keyCode) { 
        case 37:  wg_left=wg_left-10+"px";  break;
      } 
      $('wg').style.left=wg_left//要重新设置过
    }
    
    评论

报告相同问题?

悬赏问题

  • ¥15 用visual studi code完成html页面
  • ¥15 聚类分析或者python进行数据分析
  • ¥15 逻辑谓词和消解原理的运用
  • ¥15 三菱伺服电机按启动按钮有使能但不动作
  • ¥15 js,页面2返回页面1时定位进入的设备
  • ¥50 导入文件到网吧的电脑并且在重启之后不会被恢复
  • ¥15 (希望可以解决问题)ma和mb文件无法正常打开,打开后是空白,但是有正常内存占用,但可以在打开Maya应用程序后打开场景ma和mb格式。
  • ¥20 ML307A在使用AT命令连接EMQX平台的MQTT时被拒绝
  • ¥20 腾讯企业邮箱邮件可以恢复么
  • ¥15 有人知道怎么将自己的迁移策略布到edgecloudsim上使用吗?