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 相关文章推荐
ext实现完整的登录代码
Aug 08 Javascript
关于JavaScript的with 语句的使用方法
May 09 Javascript
JQuery datepicker 使用方法
May 20 Javascript
一个css与js结合的下拉菜单支持主流浏览器
Oct 08 Javascript
浏览器检测JS代码(兼容目前各大主流浏览器)
Feb 21 Javascript
Angualrjs和bootstrap相结合实现数据表格table
Mar 30 Javascript
react-router JS 控制路由跳转实例
Jun 15 Javascript
vue复合组件实现注册表单功能
Nov 06 Javascript
基于Vue中点击组件外关闭组件的实现方法
Mar 06 Javascript
Node.js文件编码格式的转换的方法
Apr 27 Javascript
改进 JavaScript 和 Rust 的互操作性并深入认识 wasm-bindgen 组件
Jul 13 Javascript
JavaScript实现简单计时器
Jun 22 Javascript
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之XML转数组函数的详解
2013/06/07 PHP
php中\r \r\n \t的区别示例介绍
2014/02/08 PHP
PHP命名空间(namespace)的动态访问及使用技巧
2014/08/18 PHP
PHP中使用BigMap实例
2015/03/30 PHP
PHP实现简单汉字验证码
2015/07/28 PHP
使用Thinkphp框架开发移动端接口
2015/08/05 PHP
PHP有序表查找之插值查找算法示例
2018/02/10 PHP
PHP调用全国天气预报数据接口查询天气示例
2019/02/20 PHP
JS BASE64编码 window.atob(), window.btoa()
2021/03/09 Javascript
防止文件缓存的js代码
2013/01/10 Javascript
js 鼠标移动显示图片的简单实例
2013/12/25 Javascript
node.js中的fs.read方法使用说明
2014/12/17 Javascript
深入分析JSON编码格式提交表单数据
2015/06/25 Javascript
JavaScript提高网站性能优化的建议(二)
2016/07/24 Javascript
javaScript中定义类或对象的五种方式总结
2016/12/04 Javascript
js Date()日期函数浏览器兼容问题解决方法
2017/09/12 Javascript
Bootstrap3.3.7导航栏下拉菜单鼠标滑过展开效果
2017/10/31 Javascript
写一个Vue Popup组件
2019/02/25 Javascript
vue轻量级框架无法获取到vue对象解决方法
2019/05/12 Javascript
JavaScript遍历数组和对象的元素简单操作示例
2019/07/09 Javascript
vue+layui实现select动态加载后台数据的例子
2019/09/20 Javascript
详细讲解Python中的文件I/O操作
2015/05/24 Python
centos6.7安装python2.7.11的具体方法
2017/01/16 Python
Python实现的弹球小游戏示例
2017/08/01 Python
简单的python协同过滤程序实例代码
2018/01/31 Python
pytorch 图像中的数据预处理和批标准化实例
2020/01/15 Python
Python configparser模块常用方法解析
2020/05/22 Python
python获取时间戳的实现示例(10位和13位)
2020/09/23 Python
CSS3 真的会替代 SCSS 吗
2021/03/09 HTML / CSS
享受加州生活方式的时尚舒适:XCVI
2018/07/09 全球购物
《二泉映月》教学反思
2014/04/15 职场文书
厕所文明标语
2014/06/11 职场文书
领导班子四风对照检查材料思想汇报
2014/09/26 职场文书
入党政审材料范文
2014/12/24 职场文书
继续教育心得体会(共6篇)
2016/01/19 职场文书
【海涛教你打DOTA】黑鸟第一视角解说
2022/04/01 DOTA