Если вы разрабатываете только для современных браузеров, вы можете использовать несколько приятных функций для этого:
- Элемент списка. Используйте тип ввода email для поля имени пользователя. Браузер позаботится о проверке.
- Использовать атрибут обязательно . Браузер не позволяет пользователю отправлять без значения в поле.
- Использовать атрибут pattern . Браузер не позволяет пользователю отправлять без значения, соответствующего данному шаблону. Хотя, с типом электронной почты, вы можете пропустить ваши ужасные регулярные выражения, соответствующие вашим письмам:)
Проверьте атрибут шаблона:
http://www.the -art-of-web.com / html / html5 форм-валидация / # section_6
* * Пример тысяча двадцать-один: * * 1 022
<input type="email" required />
Здесь вы можете проверить поддержку современных функций форм в наиболее часто используемых браузерах:
http://caniuse.com/#feat=forms
Продолжается обсуждение вопроса о возможности указания и стилизации сообщений об ошибках (обрабатываются браузером). На данный момент, я не думаю, что возможно стилизовать сообщения проверки. Может быть, удобнее, если эти сообщения одинаковы на всех страницах?
Если вам требуется поддержка старых браузеров, вам нужно будет поместить обработчики событий javascript в каждое поле, извлечь регулярное выражение из атрибутов данных и сопоставить его со значением. Имейте в виду, что проверка на стороне клиента не заменяет проверку на стороне сервера, а только для удобства пользователя. Поэтому проверка HTML5 может быть достаточно хороша для тех, у кого браузеры ее поддерживают - у остальных все равно останется проверка на стороне сервера, на которую можно положиться, хотя пользовательский опыт будет не таким уж большим.
Этот пример показывает, как это можно сделать (я не очень хорошо это проверил: o):
$('form').submit(function(){
var isValid = true;
$(this).find(':input').each(function(){
var regex = new RegExp($(this).attr('data-validation-use'));
if(!regex.exec($(this).val())){
$('.validationError').append($(this).attr('data-validation-error'));
$(this).addClass('invalid');
isValid = false;
}
});
return isValid;
});