天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

javascript的鍵盤控制事件說明

控制回車焦點問題:
復制代碼 代碼如下:
<script type="text/Javascript">
function submitForm() {
if(window.event.keyCode==13) {
document.getElementById('btnSearch').focus();
}
}
document.onkeydown=submitForm;
</script>

首先需要了解的是如何初始化該事件,基本語句如下:
   document.onkeydown = keyDown
   當瀏覽器讀到這個語句時,無論按下鍵盤上的哪個鍵,都將呼叫KeyDown()函數。
   捕獲鍵盤事件對于不同的瀏覽器來說有點困難,我們分別的來學習不同瀏覽器的實現語句。
   NETscape
   NETscape的程序實現要比IE麻煩,你必須放一個特別的語句,來使NETscape始終去檢查擊鍵事件,如果沒有這行語句,擊鍵事件將與按下鼠標事件搞混。特別語句如下:
   document.onkeydown = keyDown
if (ns4) document.captureEvents(Event.KEYDOWN)
   keyDown()函數有一個隱藏的變量--一般的,我們使用字母“e”來表示這個函數。
   function keyDown(e)
   變量e表示發生擊鍵事件,尋找是哪個鍵被按下,使用以下屬性:
   e.which
   這將給出該鍵的索引值,把索引值轉化成該鍵的字母或數字值,寫:
   String.fromCharCode(e.which)
   把上面的語句放在一起,我們可以知道被按下的是哪一個鍵:
復制代碼 代碼如下:
   function keyDown(e) {
  var keycode = e.which
  var realkey = String.fromCharCode(e.which)
  alert("keycode: " + keycode + " realkey: " + realkey)
}
   document.onkeydown = keyDown
document.captureEvents(Event.KEYDOWN)

   InterNET Explorer
   IE的程序與NETscape類似,但它不需要e變量,用window.event.keyCode來代替e.which,把鍵的索引值轉化為真實鍵值方法類似:String.fromCharCode(event.keyCode),程序如下:
復制代碼 代碼如下:
   function keyDown() {
   var keycode = event.keyCode
   var realkey = String.fromCharCode(event.keyCode)
   alert("keycode: " + keycode + " realkey: " + realkey)
}
document.onkeydown = keyDown
document.onkeydown = keyDown

   適用于兩者的程序
   用兩種瀏覽器檢查上述實例,你會發現執行結果不總是一樣的,這是因為兩種瀏覽器的鍵盤代碼設置不相同,因此你必須使用單獨的代碼分別來寫這段程序,而毫無別法。
   建議你要完全忘掉實際的鍵值,僅僅使用鍵盤的代碼值來工作。下面這段程序將視情況而設置,如果是用IE的話,ieKey生效,把nKey設為0,如果是用NETscape的話,nKey生效,把nKey設為0,然后用一個警示框來顯示兩者的值:
復制代碼 代碼如下:
   function keyDown(e) {
  if (ns4) {
   var nKey=e.which;
   var ieKey=0
  }
  if (ie4) {
   var ieKey=event.keyCode;
   var nKey=0
  }
  alert("nKey:"+nKey+" ieKey:" + ieKey)
}
document.onkeydown = keyDown
if (ns4) document.captureEvents(Event.KEYDOWN)

   使用鍵盤移動對象
   下面的程序實現用鍵盤移動對象,程序將檢查哪一個鍵被按下,從而調用相應的函數來移動對象。本例中,當字母“A”被按下時,對象就開始移動,字母“A”鍵在nKey中的值是97,ieKey的值為65,在程序中將分別檢查這兩個值。
復制代碼 代碼如下:
   function init() {
  if (ns4) block = document.blockDiv
  if (ie4) block = blockDiv.style
  block.xpos = parseInt(block.left)
  document.onkeydown = keyDown
  if (ns4) document.captureEvents(Event.KEYDOWN)
}
function keyDown(e) {
  if (ns4) { var nKey=e.which; var ieKey=0 }
  if (ie4) { var ieKey=event.keyCode; var nKey=0 }
  if (nKey==97 || ieKey==65) { // 如果"A"鍵按下
    slide()
  }
}
function slide() {
  block.xpos += 5
  block.left = block.xpos
  status = block.xpos // 這一句不一定需要,只是為了檢查狀態
  setTimeout("slide()",30)
}

   增加 "Active"變量
   上面程序稍微有些不足,對象移動以后就無法使它停止了,而且當你多按幾次A鍵時,物體將運動得越來越快,這里我們來修補它。
   使用變量"active"來改變這種情況,插入if語句來檢查函數是否重復。
復制代碼 代碼如下:
   function slide() {
  if (myobj.active) {
  myobj.xpos += 5
  myojb.left = myobj.xpos
  setTimeout("slide()",30)
  }
}

   在這種情況中,slide()函數只有在myobj.active值為真的時候才會工作,當myobj.active值為假時,對象將停止移動
   使用 onKeyUp 和 "Active" 變量
   onkeyup事件和onkeydown事件工作原理相同,用以下語句初始化該事件:
復制代碼 代碼如下:
   document.onkeydown = keyDown
document.onkeyup = keyUp
if (ns4) document.captureEvents(Event.KEYDOWN | Event.KEYUP)

   keyUp() 函數與之相同,當一個鍵被放開時事件被激發,對象停止移動,并將active變量置為0:
復制代碼 代碼如下:
   function keyUp(e) {
  if (ns4) var nKey = e.which
  if (ie4) var ieKey = window.event.keyCode
  if (nKey==97 || ieKey==65)
  block.active = false
}

   下面是比較完整的程序:
復制代碼 代碼如下:
   function init() {
  if (ns4) block = document.blockDiv
  if (ie4) block = blockDiv.style
  block.xpos = parseInt(block.left)
  block.active = false
  document.onkeydown = keyDown
  document.onkeyup = keyUp
  if (ns4) document.captureEvents(Event.KEYDOWN | Event.KEYUP)
}
function keyDown(e) {
  if (ns4) {var nKey=e.which; var ieKey=0}
  if (ie4) {var ieKey=event.keyCode; var nKey=0}
  if ((nKey==97 || ieKey==65) && !block.active) { // if "A" key is pressed
    block.active = true slide()
  }
}
function keyUp(e) {
  if (ns4) {var nKey=e.which; var ieKey=0}
  if (ie4) {var ieKey=event.keyCode; var nKey=0}
  if (nKey==97 || ieKey==65) {
  block.active = false // if "A" key is released
  }
}
function slide() {
   if (block.active) {
    block.xpos += 5
    block.left = block.xpos
    status = block.xpos // not needed, just for show
    setTimeout("slide()",30)
   }
}

JavaScript技術javascript的鍵盤控制事件說明,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 国产精品大陆在线视频 | 国内精品一级毛片免费看 | 97精品在线| 高清无码中文字幕在线观看视频 | 国产 亚洲 日韩 欧美 在线观看 | 高h喷水荡肉爽文总攻 | 国产精品一国产精品免费 | 亚洲精品国产SUV | 伊人国产在线观看 | 黑色丝袜在线观看 | 在线观看日本污污ww网站 | 日本亚洲中文字幕无码区 | 久久天天躁狠狠躁夜夜呲 | 琪琪色原网站ying | 国产精品观看视频免费完整版 | 日韩精品一区二区三区AV在线观看 | 久久精品国产99欧美精品亚洲 | 成3d漫二区三区四区 | 亚洲第一成年网站视频 | 1788福利视频在视频线 | 德国xxxx | 国产精品www视频免费看 | 国产成人精品免费视频大全可播放的 | 一二三四在线高清中文版免费观看电影 | 欧美日韩免费看 | 亚洲欧洲自拍偷拍 | 国产午夜精品美女免费大片 | 亚洲国产在线午夜视频无 | 欧美阿v天堂视频在99线 | 自拍 偷拍 亚洲 经典 | 琪琪热热色原日韩在线 | 影音先锋电影资源av | 制服国产欧美亚洲日韩 | 亚洲性夜夜夜色综合网 | 国产中文字幕一区 | 蜜芽亚洲欧美一区二区电影 | 91麻豆精品一二三区在线 | 好大好爽好深舒服死了 | 性夜影院爽黄A爽免费动漫 性夜夜春夜夜爽AA片A | 久久久精品国产免费A片胖妇女 | 亚洲熟少妇在线播放999 |