limoxin_ 2021-03-16 11:49 采纳率: 100%
浏览 77
已采纳

请教大佬键盘控制div方块移动,为什么上下只能移动一次,左右没有问题

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<style type="text/css">
			*{
				margin: 0;
				padding: 0;
			}
			#box{
				width: 100px;
				height: 100px;
				background-color: yellow;
				position: absolute;
			}
		</style>
		<script type="text/javascript">
			window.onload=function(){
				var box = document.getElementById("box");
				document.onkeydown = function(event){
					event = event || window.event;
					switch(event.keyCode){
						case 37:
							box.style.left = box.offsetLeft-10+"px";
							break;
						case 38:
							box.style.top = box.offsetHeight-10+"px";
							break;
						case 39:
							box.style.left = box.offsetLeft+10+"px";
							break;
						case 40:
							box.style.top = box.offsetHeight+10+"px";
							break;
						default:
							alert("请按下方向键");
					}
				}
			}
		</script>
	</head>
	<body>
		<div id="box"></div>
	</body>
</html>
  • 写回答

2条回答 默认 最新

  • 斯洛文尼亚旅游 2021-03-16 11:52
    关注

    offsetHeight是div高度,值不变都是一样的所以看起来就是一次性效果,改为offsetTop

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 如何用MATLAB实现以下三个公式(有相互嵌套)
  • ¥50 安装华大九天aether
  • ¥30 关于#算法#的问题:运用EViews第九版本进行一系列计量经济学的时间数列数据回归分析预测问题 求各位帮我解答一下
  • ¥15 setInterval 页面闪烁,怎么解决
  • ¥15 如何让企业微信机器人实现消息汇总整合
  • ¥50 关于#ui#的问题:做yolov8的ui界面出现的问题
  • ¥15 如何用Python爬取各高校教师公开的教育和工作经历
  • ¥15 TLE9879QXA40 电机驱动
  • ¥20 对于工程问题的非线性数学模型进行线性化
  • ¥15 Mirare PLUS 进行密钥认证?(详解)