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条)

报告相同问题?

悬赏问题

  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 保护模式-系统加载-段寄存器