JS基础小案例

112 阅读1分钟

1.键盘控制方块在固定区域内移动

//首先根据题目要求我们可以知道具体步骤如下操作:
//1.先去放两个盒子一大一小,并且获取键盘所对应的值
//2.小盒子通过设置绝对定位,键盘按下在规定区域内移动,对此补充一个知识点:
//可以利用offsetLeft和offsetTop获取移动的小箱子的当前位置距离左侧和上侧的数值:具体代码如下
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>移动色块</title>
    <style>
        .box {
            width: 500px;
            height: 500px;
            background-color: pink;
            position: relative;
        }

        .small {
            width: 50px;
            height: 50px;
            background-color: skyblue;
            position: absolute;
        }
    </style>
</head>
<!-- 
    
        // 1. 布局一个盒子宽高500,使用定位属性在内部定义小盒子宽高50
        // 2.准备四个按钮,表示上下左右
        // 3.大盒子的左外边距100 上外边距120
    需求:
        1.使用上下左右键,控制小盒子移动
        2.不能超出大盒子返回.
    解析:
        1.如何确定按下的键
        2.绑定键盘按下的事件,执行什么功能?移动色块->设置偏移量
        3.    
 -->

<body>
    <div class="box">
        <div class="small"></div>

    </div>
    <button></button>
    <button></button>
    <button></button>
    <button></button>
</body>
<script>
    //  左37 上38 右39 下40
    var box = document.querySelector(".box");
    var small = document.querySelector(".small")
    document.onkeydown = function (e) {
        console.log(e.keyCode);
        switch (e.keyCode) {
            // 只能用上左
            case 37:
                if (small.offsetLeft != 0) {
                    small.style.left = small.offsetLeft - 50 + 'px';
                }
                break;

            case 38:
                if (small.offsetTop != 0) {
                    small.style.top = small.offsetTop - 50 + 'px';
                }
                break;
            case 39:
                // small.offsetLeft返回小盒子距离左侧的数值
                if (small.offsetLeft != 450) {
                    small.style.left = small.offsetLeft + 50 + 'px';
                }
                break;
            case 40:
                // small.offsetTop返回小盒子距离上侧的数值
                if (small.offsetTop != 450)
                    small.style.top = small.offsetTop + 50 + 'px';
                break;

            default:
                break;
        }
    }
</script>

</html>