欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

鍵盤控制事件應(yīng)用教程大全

 更新時間:2006年11月24日 00:00:00   作者:  
獲取鍵盤控制事件是實現(xiàn)交互性最有力的方法之一。 

   首先需要了解的是如何初始化該事件,基本語句如下: 

   document.onkeydown = keyDown 

   當瀏覽器讀到這個語句時,無論按下鍵盤上的哪個鍵,都將呼叫KeyDown()函數(shù)。 

   捕獲鍵盤事件對于不同的瀏覽器來說有點困難,我們分別的來學(xué)習(xí)不同瀏覽器的實現(xiàn)語句。 

   Netscape 

   Netscape的程序?qū)崿F(xiàn)要比IE麻煩,你必須放一個特別的語句,來使Netscape始終去檢查擊鍵事件,如果沒有這行語句,擊鍵事件將與按下鼠標事件搞混。特別語句如下: 

   document.onkeydown = keyDown 
if (ns4) document.captureEvents(Event.KEYDOWN) 

   keyDown()函數(shù)有一個隱藏的變量--一般的,我們使用字母“e”來表示這個函數(shù)。 

   function keyDown(e) 

   變量e表示發(fā)生擊鍵事件,尋找是哪個鍵被按下,使用以下屬性: 

   e.which 

   這將給出該鍵的索引值,把索引值轉(zhuǎn)化成該鍵的字母或數(shù)字值,寫: 

   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,把鍵的索引值轉(zhuǎn)化為真實鍵值方法類似: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 

   適用于兩者的程序 

   用兩種瀏覽器檢查上述實例,你會發(fā)現(xiàn)執(zhí)行結(jié)果不總是一樣的,這是因為兩種瀏覽器的鍵盤代碼設(shè)置不相同,因此你必須使用單獨的代碼分別來寫這段程序,而毫無別法。 

   建議你要完全忘掉實際的鍵值,僅僅使用鍵盤的代碼值來工作。下面這段程序?qū)⒁暻闆r而設(shè)置,如果是用IE的話,ieKey生效,把nKey設(shè)為0,如果是用Netscape的話,nKey生效,把nKey設(shè)為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) 

   使用鍵盤移動對象 

   下面的程序?qū)崿F(xiàn)用鍵盤移動對象,程序?qū)z查哪一個鍵被按下,從而調(diào)用相應(yīng)的函數(shù)來移動對象。本例中,當字母“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 // 這一句不一定需要,只是為了檢查狀態(tài) 
  setTimeout("slide()",30) 


   增加 "Active"變量 

   上面程序稍微有些不足,對象移動以后就無法使它停止了,而且當你多按幾次A鍵時,物體將運動得越來越快,這里我們來修補它。 

   使用變量"active"來改變這種情況,插入if語句來檢查函數(shù)是否重復(fù)。 

   function slide() { 
  if (myobj.active) { 
  myobj.xpos += 5 
  myojb.left = myobj.xpos 
  setTimeout("slide()",30) 
  } 


   在這種情況中,slide()函數(shù)只有在myobj.active值為真的時候才會工作,當myobj.active值為假時,對象將停止移動。 

   使用 onKeyUp 和 "Active" 變量 

   onkeyup事件和onkeydown事件工作原理相同,用以下語句初始化該事件: 

   document.onkeydown = keyDown 
document.onkeyup = keyUp 
if (ns4) document.captureEvents(Event.KEYDOWN | Event.KEYUP) 

   keyUp() 函數(shù)與之相同,當一個鍵被放開時事件被激發(fā),對象停止移動,并將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) 
   } 

相關(guān)文章

  • JavaScript刷新頁面的幾種方法總結(jié)

    JavaScript刷新頁面的幾種方法總結(jié)

    這篇文章主要介紹了JavaScript刷新頁面的幾種方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • JavaScript中關(guān)于indexOf的使用方法與問題小結(jié)

    JavaScript中關(guān)于indexOf的使用方法與問題小結(jié)

    indexOf方法的作用是:根據(jù)給定參數(shù)x返回目標字符串(可以看成字符的數(shù)組)或數(shù)組中與x相等的項的索引。
    2010-08-08
  • javascript實現(xiàn)dom元素可拖動

    javascript實現(xiàn)dom元素可拖動

    HTML DOM 是 W3C 標準(是 HTML 文檔對象模型的英文縮寫,Document Object Model for HTML)。通過 DOM,可以訪問所有的 HTML 元素,連同它們所包含的文本和屬性??梢詫ζ渲械膬?nèi)容進行修改和刪除,同時也可以創(chuàng)建新的元素。
    2016-03-03
  • javascript類型轉(zhuǎn)換使用方法

    javascript類型轉(zhuǎn)換使用方法

    這篇文章主要介紹了javascript類型轉(zhuǎn)換的使用方法,包括轉(zhuǎn)換為字符串、轉(zhuǎn)換為數(shù)字、轉(zhuǎn)換為布爾值、轉(zhuǎn)換為對象使用方法,大家參考使用吧
    2014-02-02
  • javascript 的Document屬性和方法集合

    javascript 的Document屬性和方法集合

    JS的Document屬性和方法,希望大家了解下,方便以后的開發(fā)應(yīng)用。
    2010-01-01
  • 詳解JavaScript中setSeconds()方法的使用

    詳解JavaScript中setSeconds()方法的使用

    這篇文章主要介紹了詳解JavaScript中setSeconds()方法的使用,是JS入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下
    2015-06-06
  • javascript事件綁定學(xué)習(xí)要點

    javascript事件綁定學(xué)習(xí)要點

    這篇文章主要介紹了javascript事件綁定學(xué)習(xí)要點,主要包含下面四個方面1.傳統(tǒng)事件綁定的問題,2.W3C事件處理函數(shù),3.IE事件處理函數(shù),4.事件對象的其他補充,有需要的小伙伴可以參考下
    2016-03-03
  • JavaScript入門之語言基礎(chǔ)

    JavaScript入門之語言基礎(chǔ)

    本文通過全面列舉基礎(chǔ)的JavaScript概念這一方式來闡述該語言的基本原理,以此來為初學(xué)者提供一個對語言的基本了解,隨處可見的代碼例子則是用來說明所有的這些概念是如何在語言中體現(xiàn)出來的
    2011-10-10

最新評論