键盘事件练习——移动的方块

复制代码
<!DOCTYPE html>
<html>

    <head>
        <meta charset="utf-8" />
        <title></title>
        <style type="text/css">
            * {
                margin: 0;
                padding: 0;
            }
        </style>
    </head>

    <body style="position: relative;">
        <div id="box" style="width: 100px;height: 100px;background-color: sandybrown;position: absolute;">

        </div>
        <script type="text/javascript">

/*获取浏览器的最大化尺寸*/ var wi = document.documentElement.clientWidth - 100; //取得浏览器页面可视区域的宽度,(并且需要减去 方块的宽度) var hi = document.documentElement.clientHeight - 100; //取得浏览器页面可视区域的高度,(并且需要减去 方块的高度) var box = document.getElementById("box") document.addEventListener("keydown", function(e) { var l = parseInt(window.getComputedStyle(box, null).left); //获取方块坐标 var t = parseInt(window.getComputedStyle(box, null).top); console.log(l, t) var event = e || window.event if(event.key == "w" & t > 0) { box.style.top = t - 10 + "px"; }; if(event.key == "s" & t < hi) { box.style.top = t + 10 + "px"; }; if(event.key == "a" & l > 0) { box.style.left = l - 10 + "px"; }; if(event.key == "d" & l < wi) { box.style.left = l + 10 + "px"; }; }, false) </script> </body> </html>
复制代码

 

posted @   AAA五金批发王建军  阅读(217)  评论(0编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架
历史上的今天:
2018-02-05 心灵魔术===数字
2018-02-05 python实战===百度文字识别sdk
2018-02-05 python实战===用python对比两张图片的不同
点击右上角即可分享
微信分享提示