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 相关文章推荐
javascript实现删除前弹出确认框
Jun 04 Javascript
JS实现仿Windows经典风格的选项卡Tab切换代码
Oct 20 Javascript
Javascript复制实例详解
Jan 28 Javascript
canvas实现绘制吃豆鱼效果
Jan 12 Javascript
详解如何将angular-ui的图片轮播组件封装成一个指令
May 09 Javascript
js实现日期显示的一些操作(实例讲解)
Jul 27 Javascript
Vue中的vue-resource示例详解
Nov 02 Javascript
vue服务端渲染操作简单入门实例分析
Aug 28 Javascript
js实现掷骰子小游戏
Oct 24 Javascript
在实例中重学JavaScript事件循环
Dec 03 Javascript
Java 生成随机字符的示例代码
Jan 13 Javascript
Vue常用API、高级API的相关总结
Feb 02 Vue.js
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 stream_context_create()作用和用法分析
2011/03/29 PHP
php cc攻击代码与防范方法
2012/10/18 PHP
关于尾递归的使用详解
2013/05/02 PHP
PHP 记录访客的浏览信息方法
2018/01/29 PHP
php curl优化下载微信头像的方法总结
2018/09/07 PHP
JS实现在Repeater控件中创建可隐藏区域的代码
2010/09/16 Javascript
JS target与currentTarget区别说明
2011/08/28 Javascript
JavaScript实现QueryString获取GET参数的方法
2013/07/02 Javascript
点击进行复制的JS代码实例
2013/08/23 Javascript
详谈LABJS按需动态加载js文件
2015/05/07 Javascript
Javascript 高阶函数使用介绍
2015/06/15 Javascript
使用AngularJS创建自定义的过滤器的方法
2015/06/18 Javascript
jQuery中$(function() {});问题详解
2015/08/10 Javascript
JS+CSS实现简单滑动门(滑动菜单)效果
2015/09/19 Javascript
总结jQuery插件开发中的一些要点
2016/05/16 Javascript
功能强大的Bootstrap使用手册(一)
2016/08/02 Javascript
javascript self对象使用详解
2016/10/18 Javascript
微信小程序如何获知用户运行小程序的场景教程
2017/05/17 Javascript
深究AngularJS如何获取input的焦点(自定义指令)
2017/06/12 Javascript
python搭建微信公众平台
2016/02/09 Python
实例讲解Python爬取网页数据
2018/07/08 Python
Django基础知识与基本应用入门教程
2018/07/20 Python
对python for 文件指定行读写操作详解
2018/12/29 Python
总结Python图形用户界面和游戏开发知识点
2019/05/22 Python
如何让python的运行速度得到提升
2020/07/08 Python
Python自动化操作实现图例绘制
2020/07/09 Python
深入理解Python变量的数据类型和存储
2021/02/01 Python
Debenhams百货英国官方网站:Debenhams UK
2016/07/12 全球购物
存储过程的优缺点是什么
2015/01/10 面试题
药物学专业学生的自我评价
2013/10/27 职场文书
法学函授自我鉴定
2014/02/06 职场文书
2014年小学工作总结
2014/11/26 职场文书
长城英文导游词
2015/01/30 职场文书
风雨哈佛路观后感
2015/06/03 职场文书
2016高中社会实践心得体会范文
2016/01/14 职场文书
MySQL中连接查询和子查询的问题
2021/09/04 MySQL