|
|
|
| Какое событие происходит, когда фокус на текстовом поле и пользователь жмет интер | |
|
|
|
|
|
|
|
для: winflip
(06.01.2008 в 14:41)
| | onSubmit() | |
|
|
|
|
|
|
|
для: winflip
(06.01.2008 в 14:41)
| | Событий несколько, бывает 3 или 4.
Сначала система фиксирует события keydown и keypress, а когда пользователь отпускает кнопку - то ещё и keyup.
В случае, если указанное текстовое поле - единственное в форме, то тогда дополнительно (ещё ДО события keyup) происходит событие submit этой формы:
<html>
<head>
<script>
var z = '', n = 1;
function f (x) {z += n++ + '. ' + x + '; '}
</script>
</head>
<body onload="document.forms [0].txt.focus ()">
<form onsubmit="f ('SUBMIT'); return false">
<input name="txt" onkeyup="f ('UP')" onkeydown="f ('DOWN')" onkeypress="f ('PRESS')">
</form>
<input type="button" onclick="alert (z)" value="TEST">
</body>
</html>
| Запустите, нажмите ENTER, а потом кликните по кнопке TEST | |
|
|
|
|
|
|
|
для: CNT
(06.01.2008 в 16:06)
| | Я это в принципе знаю. Только вот как сделать так, чтобы по нажатия интер форма не отсылалась а исполнялась функция? | |
|
|
|
|
|
|
|
для: winflip
(06.01.2008 в 19:21)
| | Как сделать, чтобы форма не отправлялась - в коде уже есть - прописываете return false в атрибуте ONSUBMIT формы.
Только сделать отмену надо по условию - не сабмитить форму в случае нажатия ENTER в текстовом поле. А узнать, что это был именно ENTER, правильнее всего будет в атрибуте ONKEYDOWN тега <INPUT>, ибо он, как видно из предыдущего примера, "зажигается" первым из всех возможных событий.
Поэтому - вводим глобальную (вне функций) переменную var mKEY = 0 и в ONKEYDOWN тега <INPUT> присваиваем этой переменной keyCode последней нажатой клавиши. А в ONSUBMIT формы проверяем - если это клавиша "ENTER" (mKEY == 13), то return false (и обнуление переменной mKEY)
Все понятно, или код нужен? :-) | |
|
|
|
|
|
|
|
для: CNT
(07.01.2008 в 06:11)
| | спасибо. код не нужен. попробую сам | |
|
|
|