js实现键盘控制div的移动,且解决停顿问题

解决原生js通过键盘控制div移动,解决停顿问题

<!DOCTYPE html>
<html>

	<head>
		<meta charset="UTF-8">
		<title></title>
		<style type="text/css">
			#div1 {
				width: 100px;
				height: 100px;
				background-color: red;
				position: absolute;
				left: 100px;
				top: 100px;
			}
		</style>
		<script type="text/javascript">
			window.onload = function(){
				//			↑:38
			//			→:39
			//			↓:40
			//			←:37
			//创建各个方向条件判断初始变量
			var oDiv = document.getElementById('div1');
			var left = false;
			var right = false;
			var top = false;
			var bottom = false;

			//当按下对应方向键时,对应变量为true
			document.onkeydown = function(ev) {
				var oEvent = ev || event;
//				var oDiv = document.getElementById('div1');
				//				alert(oEvent.keyCode);
				var keyCode = oEvent.keyCode;
				switch(keyCode) {
					case 37:
						left=true;
						break;
					case 38:
						top=true;
						break;
					case 39:
						right=true;
						break;
					case 40:
						bottom=true;
						break;
				}
			}
				//设置一个定时,时间为50左右,不要太高也不要太低
				setInterval(function() {
					//当其中一个条件为true时,则执行当前函数(移动对应方向)
					if(left) {
						oDiv.style.left = oDiv.offsetLeft - 10 + "px";
					} else if(top) {
						oDiv.style.top = oDiv.offsetTop - 10 + "px";
					} else if(right) {
						oDiv.style.left = oDiv.offsetLeft + 10 + "px";
					} else if(bottom) {
						oDiv.style.top = oDiv.offsetTop + 10 + "px";
					}
				}, 50);

				//执行完后,所有对应变量恢复为false,保持静止不动
				document.onkeyup = function(ev) {
					var oEvent = ev || event;
					var keyCode = oEvent.keyCode;

					switch(keyCode) {
						case 37:
							left = false;
							break;
						case 38:
							top = false;
							break;
						case 39:
							right = false;
							break;
						case 40:
							bottom = false;
							break;
					}
				}
			}
		</script>
	</head>

	<body>
		<div id="div1">

		</div>
	</body>

</html>

 

  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值