练习:键盘移动DIV

2018-02-08  本文已影响0人  虎三呀
<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <title></title>
        <style type="text/css">
            #box1{
                width: 100px;
                height: 100px;
                background-color: red;
                position: absolute;
            }
            
            
        </style>
        
        <script type="text/javascript">
            
            //使div可以根据不同的方向键向不同的方向移动
            /*
             * 按左键,div向左移
             * 按右键,div向右移
             * 。。。
             */
            window.onload = function(){
                
                    
                //定义一个变量,来表示移动的速度
                var speed = 10;
                
                //创建一个变量表示方向
                //通过修改dir来影响移动的方向
                var dir = 0;
                
                //开启一个定时器,来控制div的移动
                setInterval(function(){
                    /*
                     * 37 左
                     * 38 上
                     * 39 右
                     * 40 下
                     */
                    switch(dir){
                        case 37:
                            //alert("向左"); left值减小
                            box1.style.left = box1.offsetLeft - speed + "px";
                            break;
                        case 39:
                            //alert("向右");
                            box1.style.left = box1.offsetLeft + speed + "px";
                            break;
                        case 38:
                            //alert("向上");
                            box1.style.top = box1.offsetTop - speed + "px";
                            break;
                        case 40:
                            //alert("向下");
                            box1.style.top = box1.offsetTop + speed + "px";
                            break;
                    }
                },30);
                
                
                
                //为document绑定一个按键按下的事件
                document.onkeydown = function(event){
                    event = event || window.event;
                    
                    //当用户按了ctrl以后,速度加快
                    if(event.ctrlKey){
                        speed = 500;
                    }else{
                        speed = 10;
                    }
                    
                    //使dir等于按键的值
                    dir = event.keyCode;
                };
                
                //当按键松开时,div不再移动
                document.onkeyup = function(){
                    //设置方向为0
                    dir = 0;
                };
                
            };
            
            
        </script>
    </head>
    <body>
        <div id="box1"></div>
    </body>
</html>

上一篇下一篇

猜你喜欢

热点阅读