js实现键盘控制DIV移动的方法


Posted in Javascript onJanuary 10, 2015

本文实例讲述了js实现键盘控制DIV移动的方法。分享给大家供大家参考。具体分析如下:

css样式部分:

<style type="text/css"> 

html,body{overflow:hidden;}

body{margin:0;padding:0;}

pre{color:green;padding:10px 15px;background:#f0f0f0;border:1px dotted #333;font:12px/1.5 Courier New;margin:12px;}

span{color:#999;}

#box{position:absolute;top:50px;left:300px;width:100px;height:100px;background:red;}

</style>

js部分:

<script type="text/javascript"> 

window.onload = function ()

{

var oBox = document.getElementById("box");

var bLeft = bTop = bRight = bBottom = bCtrlKey = false;
setInterval(function ()

{

if (bLeft)

{

oBox.style.left = oBox.offsetLeft - 10 + "px"

}

else if (bRight)

{

oBox.style.left = oBox.offsetLeft + 10 + "px"

}
if (bTop)

{

oBox.style.top = oBox.offsetTop - 10 + "px" 

}

else if(bBottom)

{

oBox.style.top = oBox.offsetTop + 10 + "px"

}

//防止溢出

limit();

},30); 
document.onkeydown = function (event)

{

var event = event || window.event;

bCtrlKey = event.ctrlKey;
switch (event.keyCode)

{

case 37:

bLeft = true;

break;

case 38:

if(bCtrlKey)

{

var oldWidth = oBox.offsetWidth;

var oldHeight = oBox.offsetHeight;
oBox.style.width = oBox.offsetWidth * 1.5 + "px";

oBox.style.height = oBox.offsetHeight * 1.5 + "px"; 
oBox.style.left = oBox.offsetLeft - (oBox.offsetWidth - oldWidth) / 2 + "px";

oBox.style.top = oBox.offsetTop - (oBox.offsetHeight - oldHeight) / 2 + "px";
break; 

}

bTop = true;

break;

case 39:

bRight = true;

break;

case 40:

if(bCtrlKey)

{

var oldWidth = oBox.offsetWidth;

var oldHeight = oBox.offsetHeight;
oBox.style.width = oBox.offsetWidth * 0.75 + "px";

oBox.style.height = oBox.offsetHeight * 0.75 + "px"; 
oBox.style.left = oBox.offsetLeft - (oBox.offsetWidth - oldWidth) / 2 + "px";

oBox.style.top = oBox.offsetTop - (oBox.offsetHeight - oldHeight) / 2 + "px";
break; 

}

bBottom = true;

break;

case 49:

bCtrlKey && (oBox.style.background = "green");

break;

case 50:

bCtrlKey && (oBox.style.background = "yellow");

break;

case 51:

bCtrlKey && (oBox.style.background = "blue");

break;

}
return false

};
document.onkeyup = function (event)

{

switch ((event || window.event).keyCode)

{

case 37:

bLeft = false;

break;

case 38:

bTop = false;

break;

case 39:

bRight = false;

break;

case 40:

bBottom = false;

break;

}

};
//防止溢出

function limit()

{

var doc = [document.documentElement.clientWidth, document.documentElement.clientHeight]

//防止左侧溢出

oBox.offsetLeft <=0 && (oBox.style.left = 0);

//防止顶部溢出

oBox.offsetTop <=0 && (oBox.style.top = 0);

//防止右侧溢出

doc[0] - oBox.offsetLeft - oBox.offsetWidth <= 0 && (oBox.style.left = doc[0] - oBox.offsetWidth + "px");

//防止底部溢出

doc[1] - oBox.offsetTop - oBox.offsetHeight <= 0 && (oBox.style.top = doc[1] - oBox.offsetHeight + "px")

}

};

</script>

说明:

上:↑ 下:↓ 左:← 右:→
Ctrl + 1 : 背景变为绿色
Ctrl + 2 : 背景变为黄色
Ctrl + 3 : 背景变为蓝色
Ctrl + ↑ : 放大
Ctrl + ↓ : 缩小

html部分:

被移动的方块【DIV】

<div id="box"></div>

希望本文所述对大家的javascript程序设计有所帮助。

Javascript 相关文章推荐
各种效果的jquery ui(接口)介绍
Sep 17 Javascript
passwordStrength 基于jquery的密码强度检测代码使用介绍
Oct 08 Javascript
jQuery.extend 函数的详细用法
Jun 27 Javascript
用JavaScript修改CSS属性的代码
May 06 Javascript
jQuery中:disabled选择器用法实例
Jan 04 Javascript
Javascript中的return作用及javascript return关键字用法详解
Nov 05 Javascript
字符串反转_JavaScript
Apr 28 Javascript
Javascript中作用域的详细介绍
Oct 06 Javascript
Bootstrap按钮功能之查询按钮和重置按钮
Oct 26 Javascript
对比分析Django的Q查询及AngularJS的Datatables分页插件
Feb 07 Javascript
jQuery事件_动力节点Java学院整理
Jul 05 jQuery
jQuery与vue实现拖动验证码功能
Jan 30 jQuery
js实现jquery的offset()方法实例
Jan 10 #Javascript
《JavaScript DOM 编程艺术》读书笔记之JavaScript 图片库
Jan 09 #Javascript
《JavaScript DOM 编程艺术》读书笔记之DOM基础
Jan 09 #Javascript
《JavaScript DOM 编程艺术》读书笔记之JavaScript 语法
Jan 09 #Javascript
《JavaScript DOM 编程艺术》读书笔记之JavaScript 简史
Jan 09 #Javascript
javascript获取四位数字或者字母的随机数
Jan 09 #Javascript
JS JQUERY实现滚动条自动滚到底的方法
Jan 09 #Javascript
You might like
php db类库进行数据库操作
2009/03/19 PHP
PHP转盘抽奖接口实例
2015/02/09 PHP
Yii2中cookie用法示例分析
2016/07/18 PHP
PHP检测一个数组有没有定义的方法步骤
2019/07/20 PHP
Jquery ui css framework
2010/06/28 Javascript
精选的10款用于构建良好易用性网站的jQuery插件
2011/01/23 Javascript
javascript的函数、创建对象、封装、属性和方法、继承
2011/03/10 Javascript
Ext修改GridPanel数据和字体颜色、css属性等
2014/06/13 Javascript
setTimeout()递归调用不加引号出错的解决方法
2014/09/05 Javascript
javascript笔记之匿名函数和闭包
2017/02/06 Javascript
利用js的闭包原理做对象封装及调用方法
2017/04/07 Javascript
JavaScript事件处理程序详解
2017/09/19 Javascript
微信小程序项目实践之主页tab选项实现
2018/07/18 Javascript
JavaScript实现汉字转换为拼音及缩写的方法示例
2019/03/28 Javascript
利用node 判断打开的是文件 还是 文件夹的实例
2019/06/10 Javascript
Vue之封装公用变量以及实现方式
2020/07/31 Javascript
React实现评论的添加和删除
2020/10/20 Javascript
python中bisect模块用法实例
2014/09/25 Python
Python2.6版本中实现字典推导 PEP 274(Dict Comprehensions)
2015/04/28 Python
python实现在控制台输入密码不显示的方法
2015/07/02 Python
Python操作MySQL数据库9个实用实例
2015/12/11 Python
一行代码让 Python 的运行速度提高100倍
2018/10/08 Python
python 切换root 执行命令的方法
2019/01/19 Python
解决Python列表字符不区分大小写的问题
2019/12/19 Python
Python写捕鱼达人的游戏实现
2020/03/31 Python
详解python程序中的多任务
2020/09/16 Python
香港卓悦化妆品官网:BONJOUR
2017/09/21 全球购物
英国家居装饰品、户外家具和玻璃器皿购物网站:Rinkit.com
2019/11/04 全球购物
在校生钳工实习自我鉴定
2013/09/19 职场文书
暑期实践思想汇报
2014/01/06 职场文书
剪彩仪式主持词
2014/03/19 职场文书
活动总结报告格式
2014/05/09 职场文书
元旦趣味活动方案
2014/08/22 职场文书
初中信息技术教学反思
2016/02/16 职场文书
写给消防战士们的一封慰问信
2019/10/07 职场文书
浅谈JS和Nodejs中的事件驱动
2021/05/05 NodeJs