国产自操久久,9999在线观看,日韩中文字幕,中文字幕精品视频在线,5151精品国产人成在线观看,狠狠色综合久久婷婷色天使 ,国产精品一区二区男人吃奶

js鍵盤操作實現(xiàn)div的移動或改變的原理及代碼

時間:2025-05-30 18:16:47 好文 我要投稿
  • 相關(guān)推薦

js鍵盤操作實現(xiàn)div的移動或改變的原理及代碼

  js鍵盤操作實現(xiàn)div的移動或改變的原理及代碼

js鍵盤操作實現(xiàn)div的移動或改變的原理及代碼

  昨天記錄了獲取鍵盤按鍵的值的事件,有了值,無非就是針對不同值做不同的操作嘛,而且之前曾經(jīng)在寫貪吃蛇時也用到過。這樣我們先來分析,要實現(xiàn)鍵盤操作實現(xiàn)div的移動大概的原理吧:

  1、要實現(xiàn)div的移動,首先最關(guān)鍵的一點:獲取div對象

  2、postion:absolute將div完全從文檔流中拖出啊,這個地方漏掉了,回去看了貪吃蛇才發(fā)現(xiàn)的,真暈

  3、獲取鍵盤的操作

  4、根據(jù)鍵盤的不同操作,給出不同響應(yīng)

  這就是我想起的大概需要注意的地方,還是先來看代碼:

  先是html部分

  然后記錄下javascript的實際操作

  ad=function(){ var obj=lementById("showZone");//獲取到對象了吧,這最簡單 var a=10; var toLeft=toRight=toTop=toBottom=false;//定義幾個boolean型變量,是為了后面方向操作用的,看是四個方向吧 var move=setInterval(function(){//這個地方的move定義實際上毫無意義,只是為了讓這個方法更明顯一點 if(toLeft){ =parseInt(etLeft-a)+"px";//感覺最好還是寫上parseInt,另外,因為offsetLeft是不含px的,所以不要忘記“px” } if(toRight){ =etLeft+a+"px";//不寫parseInt也可以,難道是因為javascript的執(zhí)行順序?執(zhí)行+,再執(zhí)行+,再執(zhí)行=?實現(xiàn)結(jié)果來看是 } if(toTop){ =etTop-a+"px"; } if(toBottom){ =etTop+a+"px"; } },300); //這個經(jīng)典的定時器啊,循環(huán)執(zhí)行的大神器,還記得setInterval和settimeout的區(qū)別么 ydown=function(event){ var event=event||t; switch(ode){ //哈哈,獲取到鍵盤操作了吧 case 37:toLeft=true;break;//改變變量,繼續(xù)執(zhí)行最初的循環(huán),不讓你停不能停啊 case 38:toTop=true;break; case 39:toRight=true;break; case 40:toBottom=true;break; } }; yup=function(event){ switch(ode){ case 37:toLeft=false;break;//給我變回來,讓你停就別動了 case 38:toTop=false;break; case 39:toRight=false;break; case 40:toBottom=false;break; } }; };

  就這樣,我們完成了原理分析中的需求,同時也就可以通過上、下、左、右按鍵來實現(xiàn)div的上下左右移動了,接下來,再來記錄下敏感地方吧。

  1、div需是absolute的,為這個糾結(jié)了半天實在不值得,于是查詢了下,了解了一個概念“文檔流”,文檔流,通常說是元素從上而下,自左向右進行排列,那么這個元素就是節(jié)點元素,龐大的dom啊。還是先來說說其它解釋吧,我比較喜歡的是這樣來闡述:文檔+流,文檔顧名思義就是說網(wǎng)頁文檔,而流則是輸出方式,還有的解釋說是瀏覽器的解析方式,這個貌似更形象一點,正常的文檔流,就好像是一個平面,而一個元素你把它放在哪了,它就在哪,而浮動、固定定位和相對定位,這里分析absolute,就是重新生成了一個流,脫離了它的父層標簽,就好像之前z-index為0,而這個的z-index就上了它的上面,憑空懸浮在它上面的,可以通過left、top來肆意的挪動它。

  大概意思能夠明白了,但是感覺有些地方還是沒法有效的用語言來表述,而且有些點略微有些模糊,相信隨著經(jīng)驗的累積,我能理解的更深一些。

  2、keyCode這里的大寫,onkeyup和onkeydown這里的小寫,在這個地方也是測試了下才發(fā)現(xiàn)的問題,對于javascript,每個小地方都是大問題。

  3、switch里的break;這個java里面就常碰到,就不多說了

  大概的問題就是以上幾點,而你還記得注釋的快捷鍵么,還記得其他快捷鍵么,這就出現(xiàn)了一個問題,上面做出響應(yīng)的我們只是針對單個按鍵,如果我們想用一些快捷鍵呢,該怎么設(shè)置呢?

  先來看下代碼:

  ydown=function(event){//還是跟上面差不多的代碼吧,你看出不同在哪里了么 var event=event||t; var bctrl=Key;//在這里 switch(ode){ case 37:toLeft=true;break; case 38:if(bctrl){ground="yellow";break;}toTop=true;break;//在這里, case 39:toRight=true;break; case 40:toBottom=true;break; } };

  這里碰到了event對象的另一個屬性,是在keyCode之外的另一個,ctrlKey,還是大寫哦,它的主要功能是檢查ctrl按鍵的狀態(tài),其實這樣的還有兩個:

  altKey和shiftKey,分別是對alt按鍵和shift按鍵狀態(tài)的檢查,這樣知道怎么設(shè)個快捷鍵了吧。

  其實如果是我自己寫的話,可能這樣我就已經(jīng)很滿足了,但是在翻閱搜索的時候,總能碰到心思縝密的朋友

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

  function limit(){ var doc = [ntWidth, ntHeight] //防止左側(cè)溢出 etLeft <=0 && ( = 0); //防止頂部溢出 etTop <=0 && ( = 0); //防止右側(cè)溢出 doc[0] - etLeft - etWidth <= 0 && ( = doc[0] - etWidth + "px"); //防止底部溢出 doc[1] - etTop - etHeight <= 0 && ( = doc[1] - etHeight + "px") }

  這里我附上的是網(wǎng)上的代碼在實現(xiàn)防止溢出的同時,我還想贊一下這個寫法,比我寫的果斷的要短了許多許多,以后也要試著寫短點。

【js鍵盤操作實現(xiàn)div的移動或改變的原理及代碼】相關(guān)文章:

移動插座的簡介及工作原理10-04

淺談js的異步執(zhí)行的作用08-11

鼠標,鍵盤作文12-03

鍵盤與鼠標作文10-19

鼠標與鍵盤的選擇05-18

鼠標與鍵盤的對話作文07-16

如何正確使用鍵盤05-19

當筆桿遇上鍵盤作文07-24

為什么鍵盤按鍵錯亂05-30

鍵盤與鼠標的對話作文08-03

郸城县| 洛川县| 肃宁县| 泰宁县| 昭苏县| 佛山市| 雷波县| 澎湖县| 富宁县| 富阳市| 平舆县| 新晃| 杨浦区| 万荣县| 三河市| 建宁县| 广汉市| 苏尼特左旗| 黑山县| 秦安县| 林西县| 呼伦贝尔市| 克拉玛依市| 子长县| 磐安县| 台安县| 延寿县| 突泉县| 沙洋县| 林西县| 平顺县| 商城县| 沙坪坝区| 屏东县| 灵武市| 安庆市| 韩城市| 叶城县| 乌兰县| 和平区| 前郭尔|