2000字范文,分享全网优秀范文,学习好帮手!
2000字范文 > js实现键盘控制DIV移动办法【javascript】

js实现键盘控制DIV移动办法【javascript】

时间:2023-07-31 22:57:54

相关推荐

js实现键盘控制DIV移动办法【javascript】

web前端|js教程

js,键盘,控制,DIV,移动,方法

web前端-js教程

学校网站php源码,vscode实现idea,ubuntu树状图目录结构,tomcat 部署过程,跨进程访问sqlite,小京东商家入驻插件,web前端哪些框架好,欧盟数据爬虫案例,php 文件被加密,北京seo公司seo公司,手机网站模板css,网页直播源码,html个人模板源码下载,表单页面源码,停车场管理系统源码,小程序到店自提源码lzw

css样式部分:

高校类网站源码,ubuntu 物理机 分区,在个人电脑部署tomcat,儿童爬虫图片大全,php网站如何部署到局域网,SEO优化公lzw

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;}

js部分:

招标投标源码下载,ubuntu优盘启动不了,爬虫是中文乱码,权限php,seo下拉词lzw

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")

}

};

说明:

上:↑ 下:↓ 左:← 右:→

Ctrl + 1 : 背景变为绿色

Ctrl + 2 : 背景变为黄色

Ctrl + 3 : 背景变为蓝色

Ctrl + ↑ : 放大

Ctrl + ↓ : 缩小

html部分:

被移动的方块【DIV】

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。