js键盘控制div移动,解决停顿问题
问题版本代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
|
<html> <head> <title>键盘控制div移动</title> <meta charset= "utf-8" /> <style type= "text/css" > #div1{width:100px;height:100px;background:#ff0000;position:absolute;} </style> <script type= "text/javascript" > window.onload = function (){ var oDiv = document.getElementById( "div1" ); document.onkeydown = function (ev){ var ev = ev || event; var keyCode = ev.keyCode; switch (keyCode){ case 37: oDiv.style.left = oDiv.offsetLeft-10+ "px" ; break ; case 38: oDiv.style.top = oDiv.offsetTop-10+ "px" ; break ; case 39: oDiv.style.left = oDiv.offsetLeft+10+ "px" ; break ; case 40: oDiv.style.top = oDiv.offsetTop+10+ "px" ; break ; } } } </script> </head> <body> <div id= "div1" ></div> </body> </html> |
问题描述:用js的键盘事件控制一个div移动,当按下一个方向键不放,div会先停顿一下,然后才开始持续移动。(原因:系统要区分用户是否连续输入,第一个到第二个之间有一个停顿时间)
解决方案:先开一个定时器,让div一直处于(往4个方向)准备移动的状态(初始4个方向的值都是false,div就保持在原地不动),当按下某个方向键,这个方向的值就改变为true,div就会开始往这个方向移动,松开方向键,这个方向的值就改变为false , div就停止这个方向移动了。
解决版本代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
|
<html> <head> <title>键盘控制div移动,解决停顿问题</title> <meta charset= "utf-8" /> <style type= "text/css" > #div1{width:100px;height:100px;background:#ff0000;position:absolute;} </style> <script type= "text/javascript" > window.onload = function (){ var oDiv = document.getElementById( "div1" ); var timer = null; var left = false; var right = false; var top = false; var bottom = false; setInterval( function (){ 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); document.onkeydown = function (ev){ var ev = ev || event; var keyCode = ev.keyCode; switch (keyCode){ case 37: left = true; break ; case 38: top = true; break ; case 39: right = true; break ; case 40: bottom = true; break ; } } document.onkeyup = function (ev){ var ev = ev || event; var keyCode = ev.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> |
js键盘控制div移动,解决停顿问题的更多相关文章
- js键盘控制DIV移动
<style type="text/css"> html,body{overflow:hidden;}body{margin:0;padding:0;}pre{colo ...
- 键盘控制div移动并且解决停顿问题(原生js)
<html> <head> <title>键盘控制div移动,解决停顿问题</title> <meta charset="utf-8&q ...
- JS实现用键盘控制DIV上下左右+放大缩小与变色
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- 键盘控制div移动
<!DOCTYPE html><html lang="zh-CN"><head> <meta charset="UTF-8&qu ...
- js 键盘移动div、img对象
js 键盘移动div.img对象 <html> <script type="text/javascript"> var EXtype="" ...
- 用键盘控制DIV && Div闪烁
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- js练习-控制div属性
要开始练练js了,决定先按照Ferris大大的索引表一个个练,头一个就是控制div属性啦.看似挺简单的,不过平时jquery用惯了,用起来原生js还有点手生呢. 总之就是模仿加练习啦,先看看效果: 一 ...
- 键盘控制div上下左右移动 (转)
<html> <head> <title></title> <link rel="stylesheet" type=" ...
- 用JS来控制 div的高度随浏览器变化而变化
<div id="test" style=" border: solid 1px #f00; "></div> <script t ...
随机推荐
- 一起来说 Vim 语
作为一款古老而具有持久生命力的编辑器,vim 自有它的强大之处.很多人觉得 Vim 的学习曲线太陡峭了,为了能够把 Vim 用得风生水起,不得不记忆大量的命令.如果你是 Vim 新手,刚入门就开始面对 ...
- OSI 七层模型和 TCP/IP 协议比较
OSI (Open System Interconnection), 开放式系统互联参考模型.从下到上七层模型功能及其代表协议: 物理层(Physical) :规定了激活.维持.关闭通信端点之间的 ...
- c语言结构体中的冒号的用法
结构体中常见的冒号的用法是表示位域. 有些信息在存储时,并不需要占用一个完整的字节, 而只需占几个或一个二进制位.例如在存放一个开关量时,只有0和1 两种状态, 用一位二进位即可.为了节省 ...
- ab apache Benchmarking中链接的写法 记得加上/
C:\wamp\bin\apache\Apache2.2.21\bin>ab.exe -n5 -c5 http://www.baidu.com ab.exe: invalid URL Usage ...
- hdoj1754 I Hate It【线段树区间最大值维护+单点更新】
I Hate It Time Limit: 9000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total S ...
- 利用setTimeOut 和clearTimeOut 方法控制写一个 滑动导航显示不同信息的效果
效果如图鼠标滑动导航 下边显示不同效果 html代码和css格式代码 <body><div id="tab" class="tab"> ...
- 启动RIDE时报错:wxPython not found
被这个错误折磨了一下午,关键时刻还得靠Google,原因是下载的wxPython是adm64的,安装的Python是32位的,一定要下载相匹配的文件. https://groups.google.co ...
- Js- 在一个JS文件中引用另一个JS文件
在调用文件的顶部加入下例代码: document.write(”<script language=javascript src=’/js/import.js’></script> ...
- emacs配置详解及C/C++IDE全功能配置演示(附配置文件)
我的emacs插件下载地址: http://pan.baidu.com/share/link?shareid=4196458904&uk=3708780105 说明: 1.为什么使用emacs ...
- c的基础 1. 无符号数和补码
计算机中储存和处理的信息是以二进制信号表示的.单个的位不是是很实用,而将这些位 组合在一起,加上某种解释,即给不同的可能位模式赋予含义,我们就行表示怎样有限集合的元素,即实现各种数据结构.计算机中使用 ...