king7269568 2016-09-26 03:06 采纳率: 28.6%
浏览 993
已采纳

小白求问,js控制人物键盘走动,这段简单代码错在哪

图片转换没有问题,按下方向键可以让它转,但是为什么跑不起来?已经设置了绝对定位已经left:0px;top:0px; 求大神解答。谢谢!

 <script>
    function basename(url){   //获取图片名
        var loc=url.lastIndexOf("/")+1;      

        return url.substr(loc);   
    }

    var ren=document.getElementById("ren");   

    var fx="p";   //默认跑动方向
    function changeimg(){
//      alert(basename(ren.src));
        if (basename(ren.src).charAt(2)=="1") {     
            ren.src="img/"+fx+"-2.png";                     
        } else{
            ren.src="img/"+fx+"-1.png";
        }       
    }   
    var x=0;
    var y=0;
    var xs=0;     //x速度
    var ys=0;       //y速度
    function run(){
        x+=xs;
        y+=ys;
        ren.style.top=y;
        ren.style.left=x;
    }


    setInterval(function(){         
        changeimg();   //正常
        run();          
    },100);

    function opt(){      
        var code=event.keyCode;
        switch (code){
            case 37:         
                fx="l";
                ys=0;
                xs=5;
                break;
            case 39:     
                fx="r";
                ys=0;
                xs=-5;
                break;
            case 38:        
                fx="u";
                xs=0;
                ys=-5;
                break;
            case 40:        
                fx="p";
                xs=0;
                ys=5;
                break;

        }
    }
</script>
  • 写回答

3条回答 默认 最新

  • Go 旅城通票 2016-09-26 03:51
    关注

    单位加上,要不去掉xhtml申明。

    而且没看到你执行opt函数的代码,没贴完代码?

            ren.style.top=y+'px';
            ren.style.left=x+'px'
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥60 版本过低apk如何修改可以兼容新的安卓系统
  • ¥25 由IPR导致的DRIVER_POWER_STATE_FAILURE蓝屏
  • ¥50 有数据,怎么建立模型求影响全要素生产率的因素
  • ¥50 有数据,怎么用matlab求全要素生产率
  • ¥15 TI的insta-spin例程
  • ¥15 完成下列问题完成下列问题
  • ¥15 C#算法问题, 不知道怎么处理这个数据的转换
  • ¥15 YoloV5 第三方库的版本对照问题
  • ¥15 请完成下列相关问题!
  • ¥15 drone 推送镜像时候 purge: true 推送完毕后没有删除对应的镜像,手动拷贝到服务器执行结果正确在样才能让指令自动执行成功删除对应镜像,如何解决?