jQuery – keydown / keypress / keyup Détection ENTERKEY?

Essayer de faire en sorte que jQuery détecte les entrées, mais que l’espace et les autres touches sont détectés, enter n’est pas détecté. Qu’est-ce qui ne va pas ci-dessous:

$("#entersomething").keyup(function(e) { alert("up"); var code = (e.keyCode ? e.keyCode : e.which); if (code==13) { e.preventDefault(); } if (code == 32 || code == 13 || code == 188 || code == 186) { $("#displaysomething").html($(this).val()); });  <div id="displaysomething"></div> 

http://jsfiddle.net/zeRrv/

JavaScript / jQuery

 $("#entersomething").keyup(function(e){ var code = e.which; // recommended to use e.which, it's normalized across browsers if(code==13)e.preventDefault(); if(code==32||code==13||code==188||code==186){ $("#displaysomething").html($(this).val()); } // missing closing if brace }); 

HTML

   

Je pense que vous aurez du mal avec l’événement keyup – car il déclenche la première pression sur une touche – et vous ne pourrez pas arrêter la propagation du second si vous voulez exclure la touche Enter.

jQuery Sparkle inclut un événement personnalisé pour cela. La source peut être vue ici: http://github.com/balupton/jquery-sparkle/blob/master/scripts/resources/jquery.events.js

Voici une démo http://www.balupton.com/sandbox/jquery-sparkle/demo/#event-enter