Javascript-форум (https://javascript.ru/forum/)
-   Общие вопросы Javascript (https://javascript.ru/forum/misc/)
-   -   onKeyUp/onKeyPress (https://javascript.ru/forum/misc/32626-onkeyup-onkeypress.html)

FoxTrix 23.10.2012 19:44

onKeyUp/onKeyPress
 
Здравствуйте!
Пишу проверку данных вводимых в input text.
Есть:
<input type="text" name="text" id="text" onKeyUp="control(this.value)">
и скрипт к нему
function control(str)
{
	var mask = /\W/
	var result = check(str);
	function check(str)
	{
		var result = mask.exec(str);
		return result;
	}
	
	if(result != null)
	{
		var repl = str.replace(result, '');
		control(repl);
	}
	else
	{
		if(result == null)
			document.getElementById('text').value = str;
	}
}
с onKeyUp работает как нужно, но перед удалением символ успевает отобразиться в поле, а это выглядит не очень.

нашёл решение проблемы здесь, но не могу его переделать под себя =(

если делаю с onKeyPress так
function control(str)
{
	function value()
	{
		document.getElementById('text').value = str;
		
	}
	var mask = /\W/
	var result = check(str);
	function check(str)
	{
		var result = mask.exec(str);
		return result;
	}
	
	if(result != null)
	{
		var repl = str.replace(result, '');
		control(repl);
	}
	else
	{
		if(result == null)
			setTimeout(value, 0);
	}
}
то вообще не даёт ничего ввести, удаляет всё(хотя проверка идёт)

подскажите, в чём проблема?

Hoshinokoe 23.10.2012 20:25

FoxTrix,

Почитайте про события клавиатуры http://learn.javascript.ru/keyboard-events

Порядок возникновения событий:
1) keydown
2) keypress - на момент этого события символ еще не введен в поле
3) keyup

В вашем случае, чтобы неверный символ не отображался в поле, можно использовать событие keypress и проверять какой символ ввели (если не разрешенный - то делаем preventDefault).

FoxTrix 23.10.2012 20:42

Hoshinokoe,
я знаю события клавиатуры, в ссылке которую я кидал
http://learn.javascript.ru/events-and-timing-depth
чуть ниже приведено решение, именно с onKeyPress, но под себя у меня его переделать не получается.

preventDefault для меня не подойдёт т.к. при вставке текста через Ctrl + V (если в нем присутствуют запрещённые символы) предотвратится вставка всей строки, а не только запрещённых символов

Hoshinokoe 23.10.2012 21:03

FoxTrix,

Тогда как-то так:
<input type="text" name="text" id="text"/>
<script type="text/javascript">
    document.getElementById('text').onkeypress = function () {
        var self = this;

        function handle() {
            var res = /\W/.exec(self.value);
            if (res && res.length)
                self.value = self.value.replace(res, '');
        }

        setTimeout(handle, 0);
    };
</script>

FoxTrix 23.10.2012 21:17

Hoshinokoe,
Спасибо!
немного переделал под себя, получилось так
<input type="text" name="text" id="text" onKeyDown="a(this)">

function a(self)
{
	function handle() {
		
		var res = /\W/.exec(self.value);
		if (res.length)
		{
			self.value = self.value.replace(res, '');
			a(self);
		}
	}

	setTimeout(handle, 0);
}
переделал на onKeyDown, чтобы отлавливать Ctrl+V и Shift+Insert, и добавил рекурсию для удаления нескольких символов вставленных через Ctrl+V =)
Ещё раз спасибо!)


Часовой пояс GMT +3, время: 22:40.