js实现键盘操作对div的移动或改变——-Day43

js实现键盘操作对div的移动或改变——-Day43

大家好,又见面了,我是全栈君,祝每个程序员都可以多学几门语言。

《爸爸去哪儿》的第二季据说要开播了额,有点小期待,不知道这一季的小宝贝们会有多萌,还会甜到心底吧,
哈哈,还记得那个风一样的女子呢,不知道她如今怎样了。

言归正传,继续今天的记录,实际上在刚開始的时候,我以为能够非常快的实现这个功能,毕竟昨天记录了获取键盘按键的值的事件,有了值,无非就是针对不同值做不同的操作嘛,并且之前以前在写贪吃蛇时也用到过。结果一捯饬,又是好久的一段时间,所以感觉有必要记录下的,一方面确有可取之处,还有一方面也对自己的提醒,刚刚实现过的功能转头又是陌生人了,总的来说,算是温故而知新吧。

这样我们先来分析,要实现键盘操作实现div的移动大概的原理吧:

*—要实现div的移动,首先最关键的一点:获取div对象

*—postion:absolute将div全然从文档流中拖出啊,这个地方漏掉了,回去看了贪吃蛇才发现的,真晕

*—获取键盘的操作

*—依据键盘的不同操作,给出不同响应

这就是我想起的大概须要注意的地方,还是先来看代码:

先是html部分

    <div style="width: 50px;height: 50px;background-color: cyan;position: absolute;" id="showZone">

然后记录下javascript的实际操作

window.onload=function(){
	var obj=document.getElementById("showZone");//获取到对象了吧,这最简单
	var a=10;
	var toLeft=toRight=toTop=toBottom=false;//定义几个boolean型变量,是为了后面方向操作用的,看是四个方向吧
	
	var move=setInterval(function(){//这个地方的move定义实际上毫无意义,仅仅是为了让这种方法更明显一点
		if(toLeft){
			obj.style.left=parseInt(obj.offsetLeft-a)+"px";//感觉不妨写上parseInt,另外,由于offsetLeft是不含px的,所以不要忘记“px” 
		}
		if(toRight){
			obj.style.left=obj.offsetLeft+a+"px";//不写parseInt也能够,难道是由于javascript的运行顺序?运行+,再运行+,再运行=?实现结果来看是
		}
		if(toTop){
			obj.style.top=obj.offsetTop-a+"px";
		}
		if(toBottom){
			obj.style.top=obj.offsetTop+a+"px";
		}
	},300);  //这个经典的定时器啊,循环运行的大神器,还记得setInterval和settimeout的差别么
	document.onkeydown=function(event){
		var event=event||window.event;
		switch(event.keyCode){  //哈哈,获取到键盘操作了吧
		case 37:toLeft=true;break;//改变变量,继续运行最初的循环,不让你停不能停啊
		case 38:toTop=true;break;
		case 39:toRight=true;break;
		case 40:toBottom=true;break;
		}
	};
	document.onkeyup=function(event){
		switch(event.keyCode){
		case 37:toLeft=false;break;//给我变回来,让你停就别动了
		case 38:toTop=false;break;
		case 39:toRight=false;break;
		case 40:toBottom=false;break;
		}
	};
};

就这样,我们完毕了原理分析中的需求,同一时候也就能够通过上、下、左、右按键来实现div的上下左右移动了,接下来,再来记录下敏感地方吧。

1、div需是absolute的,为这个纠结了半天实在不值得,于是查询了下,了解了一个概念“文档流”,

文档流,通常说是元素从上而下,自左向右进行排列,那么这个元素就是节点元素,庞大的dom啊。还是先来说说其他解释吧,我比較喜欢的是这样来阐述:文档+流,文档顾名思义就是说网页文档,而流则是输出方式,还有的解释说是浏览器的解析方式,这个貌似更形象一点,正常的文档流,就好像是一个平面,而一个元素你把它放在哪了,它就在哪,而浮动、固定定位和相对定位,这里分析absolute,就是又一次生成了一个流,脱离了它的父层标签,就好像之前z-index为0,而这个的z-index就上了它的上面,凭空悬浮在它上面的,能够通过left、top来肆意的挪动它。

大概意思可以明确了,可是感觉有些地方还是没法有效的用语言来表述,并且有些点稍微有些模糊,相信随着经验的累积,我能理解的更深一些。

2、keyCode这里的大写,onkeyup和onkeydown这里的小写,在这个地方也是測试了下才发现的问题,对于javascript,每一个小地方都是大问题啊;

3、switch里的break;这个java里面就常碰到,就不多说了

大概的问题就是以上几点,而你还记得凝视的快捷键么,还记得其它快捷键么,这就出现了一个问题,上面做出响应的我们仅仅是针对单个按键,假设我们想用一些快捷键呢,该怎么设置呢?

先来看下代码:

document.onkeydown=function(event){//还是跟上面差点儿相同的代码吧,你看出不同在哪里了么
		var event=event||window.event;
		var bctrl=event.ctrlKey;//在这里
		switch(event.keyCode){
		case 37:toLeft=true;break;
		case 38:if(bctrl){obj.style.background="yellow";break;}toTop=true;break;//在这里,
		case 39:toRight=true;break;
		case 40:toBottom=true;break;
		}
	};

这里碰到了
event对象的还有一个属性,是在keyCode之外的还有一个,
ctrlKey,还是大写哦,它的主要功能是检查ctrl按键的状态,事实上这种还有两个:

altKey和shiftKey,各自是对alt按键和shift按键状态的检查,这样知道怎么设个快捷键了吧。

事实上假设是我自己写的话,可能这样我就已经非常满足了,可是在翻阅搜索的时候,总能碰到心思缜密的朋友

附上代码,你知道是要做什么么:

	function limit(){
		var doc = [document.documentElement.clientWidth, document.documentElement.clientHeight]
		//防止左側溢出
		obj.offsetLeft <=0 && (<span style="font-family: Arial, Helvetica, sans-serif;">obj</span><span style="font-family: Arial, Helvetica, sans-serif;">.style.left = 0);</span>
		//防止顶部溢出
		obj.offsetTop <=0 && (obj.style.top = 0);
		//防止右側溢出
		doc[0] - obj.offsetLeft - obj.offsetWidth <= 0 && (obj.style.left = doc[0] - obj.offsetWidth + "px");
		//防止底部溢出
		doc[1] - obj.offsetTop - obj.offsetHeight <= 0 && (obj.style.top = doc[1] - obj.offsetHeight + "px")
	}

这里我附上的是网上的代码在实现
防止溢出的同一时候,我还想赞一下这个写法,比我写的果断的要短了很多很多,以后也要试着写短点。

好了,今天就到这里吧,明天还要去加班,不知道还会不会下雨。来个暖心的,他们俩事实上我都喜欢

js实现键盘操作对div的移动或改变-------Day43

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/118883.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • 数电课设分享-八路抢答器「建议收藏」

    数电课设分享-八路抢答器「建议收藏」

    2022年10月20日
  • poj 1088 记忆化搜索||动态规划

    poj 1088 记忆化搜索||动态规划poj1088    记忆化搜索也也是采用递归深搜的对数据进行搜索,但不同于直接深搜的方式,记忆化搜索是在每次搜索时将得到的结果保存下来,避免了重复计算,这就是所谓的记忆化。记忆化应该是属于动态规划。   举个例子,比如我们搜索最长最长连续增子序列,1 234567,当然这个例子比较特殊,但足以说明情况。   对于这种问题,我们可以先搜索以1开始的

  • 【Java】lamda表达式

    【Java】lamda表达式lamda表达式1.简介lamda表达式是java语言中函数式编程的一种形式。关于函数式编程,有一句话是这么介绍的,面向对象编程是对数据的抽象,而函数式编程是对行为的抽象。反映到函数的定义上,前者传参是一个对象,后者则是一个函数(对象)。lamda表达式承载了定义函数的方式。2.形式一种是直接定义,可以(a,b)->returna+b这种是直…

  • 学了一天java,我总结了这些知识点

    学了一天java,我总结了这些知识点大家好,我是KookNut39也是Tommy,在CSDN写文,写Java时候我是Tommy,分享一些自己认为在学习过程中比较重要的东西,致力于帮助初学者入门,希望可以帮助你进步。以前一直更新C/C++方面的知识,今天是我第一次更新Java方面的知识,以后会持续更新,感兴趣的欢迎关注博主,和博主一起从0学习Java知识。大家可以去专栏查看之前的文章,希望未来能和大家共同探讨技术。文章目录1.注释(1)单行注释(2)多行注释(3)文档注释2.关键字3.保留字4.标识符5.Java数据类型(1)基本数据类型.

  • 关系数据库理论之最小函数依赖集「建议收藏」

    关系数据库理论之最小函数依赖集「建议收藏」前言在本文中,会介绍为什么要引入最小函数依赖集,最小函数依赖集是什么,以及如何求最小函数依赖集。为什么需要最小函数依赖集在关系数据模型中,一个关系通常由R(U,F)构成,U为属性的全集,F为函数依赖集。在实际生活中,我们可以根据语义来定义关系中属性的依赖关系,例如学号可以唯一确定一位学生的姓名、性别等等。但是,有时候给出的函数依赖集并不是最简的,这有时会拖累我们对关系的后续处理,例如关系的分…

  • springboot多环境配置文件_Springboot教程

    springboot多环境配置文件_Springboot教程第一步:三个配置文件,分别是默认配置application.yaml、开发配置application-dev.yaml、生产配置application-pro.yaml第二步:SpringBoot默认加载的是application.yaml,想要默认加载其他配置文件,需要在application.yaml中配置:这样加载的就是生产环境的配置了,打包打的也是application-pro.yaml文件。本地开发的时候也是加载的pro文件。第三步:想要打包的时候用pro文件,IDE开发的时候用的

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号