时间:2021-05-26
本文实例为大家分享了利用键盘控制小方块的移动,供大家参考,具体内容如下
原理
1. 利用键盘控制移动,则需要了解onkeydown函数,表示某个按键被按下,可以以此绑定一个事件响应函数,当键盘被按下时候,触发此事件,进行移动
2. keyCode 对于keypress 事件,该属性声明了被敲击的键生成的 Unicode 字符码。对于 keydown 和 keyup 事件,它指定了被敲击的键的虚拟键盘码。虚拟键盘码可能和使用的键盘的布局相关。 因此我们可以根据keycode返回的字符码来判断用户所按下的键,下面就是一个用于测试上下左右按键的js代码,经过我的测试之后,返回37 38 39 40;
window.onload = function(){ var box = document.getElementById("box"); document.onkeydown = function(event){ event = event || window.event; console.log(event.keyCode); } };3.方块的移动实际上就是坐标的改变,因此需要offsetLeft 和offsetTop 来获得当前方块的坐标,然后将坐标进行一定的更改,就可以实现移动的效果了,下面给出代码
window.onload = function() { document.onkeydown = function(event) { event = event || window.event; //设置移动速度 var speed = 10; //当ctrl和方向按键同时按下时,提升移动速度 if(event.ctrlKey) { speed = 50; } //获取div var box01 = document.getElementById("box01"); switch(event.keyCode) { /*keyCode返回按下按键的编码 * 37 向左 * 38向上 * 39向右 * 40向下 */ case 37: box01.style.left = box01.offsetLeft - speed + "px"; break; case 39: box01.style.left = box01.offsetLeft + speed + "px"; break; case 38: box01.style.top = box01.offsetTop - speed + "px"; break; case 40: box01.style.top = box01.offsetTop + speed + "px"; break; } }; };这样就可以简单实现方块的移动,但是此时我们会发现一个问题,当我们进行移动的时候,按住按键不松手,理论上方块应该直接平滑的进行移动,但实际上并非如此,第一下它会有一个小的停顿,这实际上是浏览器防止误触所设置的,因此我们需要对此进行优化
解决方案
下面附上修改后的完整代码
<!DOCTYPE html><html> <head> <meta charset="UTF-8"> <title></title> <style type="text/css"> #box01 { width: 100px; height: 100px; background-color: #008000; position: absolute; } </style> <script type="text/javascript"> window.onload = function() { //获取div var box01 = document.getElementById("box01"); //设置移动速度 var speed = 10; //设置移动的方向 var dir = 0; setInterval(function() { switch(dir) { /*keyCode返回按下按键的编码 * 37 向左 * 38向上 * 39向右 * 40向下 */ case 37: box01.style.left = box01.offsetLeft - speed + "px"; break; case 39: box01.style.left = box01.offsetLeft + speed + "px"; break; case 38: box01.style.top = box01.offsetTop - speed + "px"; break; case 40: box01.style.top = box01.offsetTop + speed + "px"; break; } }, 50) document.onkeydown = function(event) { event = event || window.event; //当ctrl和方向按键同时按下时,提升移动速度 if(event.ctrlKey) { speed = 50; } else { speed = 10; } //使dir等于keycode的值 dir = event.keyCode; //当鼠标松开时,停止移动 ---如果不写这一个会造成无法停止移动的效果 document.onkeyup = function() { dir = 0; }; }; }; </script> </head> <body> <div id="box01"></div> </body></html>以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
一、Dubbo框架简介1、框架依赖图例说明:1)图中小方块Protocol,Cluster,Proxy,Service,Container,Registry,M
卡片式设计的优点如下: 1、增强点击感。手机系统界面是以一个个小方块来显示的,类似方块型的按钮设计,让人感觉到这是可以点击的,而且方块形状有大有小,不会造成视
用碎片加载小方块实现简单的随机色块,直接上代码:效果图:具体代码:koringzcss代码:*{-webkit-box-sizing:border-box;-m
打开屏幕设置点击通用设置点击辅助功能,点击开启assistivetouch。开启后,点击进入。查看默认菜单。回到桌面点击操作小方块,点击屏幕快照,就OK了。开启
照片尺寸的px的意思是像素(Pixel),每个像素是数码图片里面积最小的单位。像素越大,图片的面积越大。 像素是指由图像的小方格组成的,这些小方块都有一个明确