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条回答 默认 最新

  • 斯洛文尼亚旅游 2016-09-26 03:51
    关注

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

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

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

报告相同问题?

悬赏问题

  • ¥15 内存地址视频流转RTMP
  • ¥100 有偿,谁有移远的EC200S固件和最新的Qflsh工具。
  • ¥15 找一个QT页面+目标识别(行人检测)的开源项目
  • ¥15 有没有整苹果智能分拣线上图像数据
  • ¥20 有没有人会这个东西的
  • ¥15 cfx考虑调整“enforce system memory limit”参数的设置
  • ¥30 航迹分离,航迹增强,误差分析
  • ¥15 Chrome Manifest扩展引用Ajax-hook库拦截请求失败
  • ¥15 用Ros中的Topic通讯方式控制小乌龟的速度,走矩形;编写订阅器代码
  • ¥15 LLM accuracy检测