日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

js之按键控制div移动

發布時間:2023/12/18 编程问答 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 js之按键控制div移动 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

要求:當用戶按下鍵盤上的上下左右鍵時,讓div進行上下左右的移動

1.我們要找到事件源和事件 事件源:鍵盤

事件:鍵盤按下事件 document.οnkeydοwn=function(){}

()里填event:是事件對象:包含本次觸發事件的相關屬性。方法

2.如何判斷按的是哪個鍵:通過鍵值來判斷

event.keyCode:鍵盤的鍵值

<script>document.onkeydown=function(event){console.log(enent.keyCode)//輸出鍵盤的鍵值 } //按鍵左是37 上是38 右是39 下是40 <script>

業務:當用戶按下鍵盤上下左右鍵時,輸出對應方向

1)用if

<scirpt>if(event.keyCode==37){console.log("左") }else if(event.keyCode==38){console.log("上") }else if(event.keyCode==39){console.log("右") }else if(event.keyCode==40){console.log("下") }else{console.log("什么都不是") } </script>

2)switch 可以簡化代碼更方便,但只適用于全等判斷

格式:switch(case 值1:執行代碼 break;case 值2:執行代碼 break... default:執行代碼 break)如果只都不符合,走default

<script>switch(event.keyCode){case 37:console.log("左")break;case 38:console.log("上")break;case 39:console.log("右")break;case 40:console.log("下")break;default:console.log("什么都不是")break; } </script>

3.給div的格式添加一個相對定位屬性:position:relative;通過left 和top操作

1)如何找到當前元素的left值:

將left和top寫到div的行內樣式中 定義一個新的變量

var left=div的id值.style.left

因為left的值本來是0px,所以輸出的也是0px,但是這是一個字符串,進行數值與字符串之間的轉化

parseInt()

設置樣式

代碼

<style>#box{width: 300px;height: 300px; background-color: #ccc; position: relative;}</style> </head> <body><div id="box" style="left: 0px; top: 0px;"></div> <script>var box=document.getElementById("box")document.onkeydown=function(event){switch(event.keyCode){case 38:var top=box.style.topvar x=parseInt(top)var result=x-20box.style.top=result+"px"console.log("上")breakcase 39: //找到當前元素的left值var left=box.style.leftvar x=parseInt(left)//console.log(x)var result=x+20box.style.left=result+"px"console.log("右") breakcase 37: var left=parseInt(box.style.left)box.style.left=left-20+"px"console.log("左")breakcase 40:var top=parseInt(box.style.top)box.style.top=top+20+"px"console.log("下")breakdefault: console.log("什么都不是")break}}</script> </body>

總結

以上是生活随笔為你收集整理的js之按键控制div移动的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。