JavaScript. Подробное руководство, 6-е издание
Шрифт:
for(var і = 0 ; і < inputelts.length; i++) {
var elt = inputelts[i];
// Пропустить элементы, не являющиеся текстовыми полями ввода
// и не имеющие атрибута data-allowed-chars.
if (elt.type != "text" || !elt.getAttribute(”data-allowed-chars")) continue;
// Зарегистрировать наш обработчик
события в этом элементе input
// keypress - старое событие и реализовано во всех броузерах.
// textInput (смешанный регистр символов) поддерживается в Safari
// и Chrome с 2010 года.
// textinput (все символы строчные) - версия проекта
// стандарта "DOM Level 3 Events",
if (elt.addEventListener) {
elt.addEventListener("keypress", filter, false);
elt.addEventListener("textlnput", filter, false);
elt.addEventListened"textinput", filter, false);
}
// textinput не поддерживается версиями IE, в которых не реализован
// метод addEventListener
else {
elt.attachEvent("onkeypress", filter);
}
}
// Обработчик событий keypress и textlnput, фильтрующий ввод пользователя
function filter(event) {
// Получить объект события и целевой элемент target
var е = event || window.event; // Модель стандартная или IE
var target = e.target || e.srcElement; // Модель стандартная или IE
var text = null; // Введенный текст
// Получить введенный символ или текст
if (e.type === "textinput" || e.type === "textlnput")
text = e.data;
else { // Это было событие keypress
// Введенный печатаемый символ в Firefox сохраняется в свойстве charCode
var code = е.charCode || e.keyCode;
// Если была нажата какая-либо функциональная клавиша, не фильтровать ее
if (code < 32 || // Управляющий символ ASCII
е.charCode == 0 || // Функциональная клавиша (в Firefox)
e.ctrlKey || e.altKey) //
Удерживаемая клавиша-модификатор
return; // Не фильтровать это событие
// Преобразовать код символа в строку
var text = String.fromCharCode(code);
}
// Отыскать необходимую нам информацию в этом элементе input
var allowed = target.getAttribute("data-allowed-chars");
// Допустимые символы
var messageid = target.getAttribute("data-messageid"); // Сообщение id
if (messageid) // Если указано значение id, получить элемент
var messageElement = document.getElementByld(messageid);
// Обойти в цикле символы во введенном тексте
for(var і = 0; і < text.length; i++) {
var c = text.charAt(i);
if (allowed.indexOf(c) == -1) { // Недопустимый символ?
// Отобразить элемент с сообщением, если указан
if (messageElement) messageElement.style.visibility="visible";
// Отменить действия по умолчанию, чтобы предотвратить вставку текста
if (е.preventDefault) е.preventDefault;
if (е.returnValue) е.returnValue = false;
return false;
}
}
// Если все символы оказались допустимыми, скрыть элемент
// с сообщением, если он был указан.
if (messageElement) messageElement.style.visibility = "hidden";
}
}):
События «keypress» и «textinput» генерируются непосредственно перед фактической вставкой нового текста в элемент документа, обладающий фокусом ввода, благодаря чему обработчики этих событий могут предотвратить вставку текста, отменив событие. Броузеры также реализуют событие «input», которое возбуждается после вставки текста в элемент. Это событие нельзя отменить и соответствующий ему объект события не содержит информации о вставленном тексте - оно просто извещает о том, что текстовое содержимое элемента изменилось. Если, к примеру, потребуется обеспечить ввод только символов в верхнем регистре, можно определить обработчик события «input», как показано ниже:
Поделиться с друзьями: