Robert: returnwert von Eventhandler wird ignoriert

Beitrag lesen

Hallöle,

Folgender (aufs wesentliche reduzierte) Code

  
elem = document.getElementById("myInput");  
elem.onkeydown  = dp_onkeydown;  
elem.onkeypress = dp_onkeypress;  
elem.onkeyup    = dp_onkeyup;  
  
function dp_onkeydown(e)  
{  
  if (!e) e = self.event;  
  if (e.keyCode == 32)  
  {  
     alert("LEERTASTE");  
     return false;  
  }  
  return true;  
}  
  
function dp_onkeypress(e)  
{  
  if (!e) e = self.event;  
  if (e.keyCode == 32)  
  {  
     alert("LEERTASTE");  
     return false;  
  }  
  return true;  
}  
  
function dp_onkeyup(e)  
{  
  if (!e) e = self.event;  
  if (e.keyCode == 32)  
  {  
     alert("LEERTASTE");  
     return false;  
  }  
  return true;  
}  

verhält sich nicht ganz so wie ich es gerne hätte.

Was hätte ich gerne:
Wenn das Element <input type="text" id="myInput"> den Focus hat und die Leertaste gedrückt wird, soll der alert (stellvertretend für die später einzusetzende eigentliche Aktion) erscheinen, das Leerzeichen soll verschluckt werden. Alle anderen Tastendrücke sollen sich wie immer verhalten, sprich: die entsprechenden Zeichen ins Input eingetragen werden bzw. mit tab zum nächsten Feld gesprungen usw.

Was tatsächlich passiert:
Beim Druck der Leertaste erscheint der alert, zusätzlich wird aber das Leerzeichen ins input-Feld eingetragen.

Ich dachte eigentlich, daß das return false; das Weiterverarbeiten des Ereignisses unterdrückt, womit das Leerzeichen nicht eingetragen werden dürfte (bei allen anderen Tasten geb ich true zurück, damit das Weiterverarbeiten des Ereignisses auch klappt).

Auch das zusätzliche Abfangen der anderen Key-Ereignisse hat nichts gebracht - das Leerzeichen wird eingetragen.

Ich habe den Eindruck, daß mein Returnwert vollständig ignoriert wird.

Was kann ich dagegen tun?

cu,
Robert