JS властивість Event.input
Загальний опис
Подія input
спрацьовує щоразу, коли значення в полі введення змінюється. Ця подія є корисною для відстеження будь-яких змін у полях типу input
, textarea
, а також інших елементів форм, таких як select
. Відмінність цієї події від події change
полягає в тому, що input
спрацьовує миттєво під час редагування, у той час як change
викликається тільки після того, як користувач вийде з поля або натисне Enter.
Подія input
широко використовується для реалізації функцій, які залежать від змін користувацьких даних. Наприклад, можна створити механізм автоматичного пошуку, який оновлює результати на основі кожного введеного символа:
const inputField = document.getElementById('search');
inputField.addEventListener('input', function(event) {
const searchTerm = event.target.value;
console.log('Пошуковий запит:', searchTerm);
});
У цьому прикладі подія input
спрацьовує щоразу, коли користувач змінює текст у полі пошуку. Кожен введений символ виводиться в консоль, і цей функціонал можна розширити для відправлення запиту до сервера або для фільтрації результатів без перезавантаження сторінки.
Подія input
передає об'єкт event
, який містить багато корисної інформації, включаючи значення введеного тексту через властивість event.target.value
. Ця подія працює з усіма сучасними браузерами і є універсальним способом відстежувати зміни користувацького введення в реальному часі.
Подія input
також може використовуватися разом із методами перевірки валідації даних, що дає змогу надавати миттєвий зворотний зв’язок користувачу під час заповнення форми. Наприклад, ви можете показувати попередження, якщо введені дані не відповідають вимогам форми:
inputField.addEventListener('input', function(event) {
if (event.target.value.length < 3) {
console.log('Занадто короткий запит');
}
});
Подія input
є дуже ефективною для покращення інтерфейсу користувача, оскільки дозволяє реалізувати функціонал "живого" зворотного зв'язку на сторінках з формами.
Порада: | Якщо ви використовуєте подію |
Порада: | Подія |
Порада: | Для текстових полів, таких як |
Синтаксис
element.addEventListener('input', function(event) {
// Ваш код тут
});
Значення
Return
Переглядачі
Переглядач | |||||
---|---|---|---|---|---|
66 |
57 |
11.1 |
53 |
16 |
Переглядач | ||||
---|---|---|---|---|
66 |
66 |
57 |
11.3 |
Переглядач | ||
---|---|---|
15.0.0 |
1.0 |
Приклади
Цей приклад демонструє інтерактивну роботу з подією input
. Користувач вводить текст у поле, і цей текст одразу відображається у блоці попереднього перегляду під полем. Якщо користувач очищує поле, у блоці попереднього перегляду відображається текст "Зараз тут нічого немає...". Це дозволяє миттєво бачити результат введених даних, що може бути корисним для створення інтерфейсів з динамічним відображенням введеної інформації.
У цьому прикладі подія input
використовується для запуску функції пошуку при введенні користувачем запиту. Коли кількість символів перевищує 2, функція fetchResults
імітує запит та відображає результати в контейнері.
const searchInput = document.getElementById('search-input');
const resultsContainer = document.getElementById('results');
searchInput.addEventListener('input', function() {
const query = searchInput.value.trim();
if (query.length > 2) {
fetchResults(query);
} else {
resultsContainer.innerHTML = '';
}
});
function fetchResults(query) {
// Імітація отримання результатів пошуку
const results = ['Результат 1', 'Результат 2', 'Результат 3'].filter(item => item.toLowerCase().includes(query.toLowerCase()));
resultsContainer.innerHTML = results.map(result => `<p>${result}</p>`).join('');
}
Цей приклад показує, як можна використовувати подію input
для динамічної валідації пароля. Кожен раз, коли користувач вводить або змінює пароль, перевіряється його довжина і миттєво виводиться повідомлення, якщо пароль занадто короткий.
const passwordInput = document.getElementById('password');
const validationMessage = document.getElementById('validation-message');
passwordInput.addEventListener('input', function() {
const password = passwordInput.value;
if (password.length < 6) {
validationMessage.textContent = 'Пароль має містити щонайменше 6 символів';
} else {
validationMessage.textContent = '';
}
});