JavaScript练习—键盘移动div

<!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">
        window.onload = function () {

            // 定义一个变量,来表示移动的速度
            var speed = 10;
            //创建一个变量表示方向
            var dir = 0;


            // 开启一个定时器,来控制div的移动
            setInterval(function () {
                switch (dir) {
                    /*
                        37左
                        38上
                        39右
                        40下
                    */
                    // console.log(event.keyCode);
                    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)

            //使div可以根据不同的方向键向不同的方向移动
            /*  
                按左键,div向左移
                按右键,div向右移
            */
            //为document绑定一个按键按下的事件
            document.onkeydown = function (event) {
                event = event || window.event;

                //当用户按了ctrl以后,速度加快
                if (event.ctrlKey) {
                    speed = 50;
                } else {
                    speed = 10;
                }

                // 使dir等于按键的值
                dir = event.keyCode;
            };

            //当按键松开时,div不再移动
            document.onkeyup = function () {
                dir = 0;
            };

        }
    </script>
</head>

<body>
    <div id="box1"></div>
</body>

</html>

 

posted @ 2020-08-02 15:27  我等着你  阅读(185)  评论(0编辑  收藏  举报