Задать вопрос
blood-moon
@blood-moon
Фрилансер

Как отловить отправку формы не только кнопкой?

Как отловить отправку формы не только по кнопке но и через enter ?
Мне нужно обработать данные перед тем как отправлю их на бек . С jquery такое делал но сейчас нужно на ванильном js
ps Гугл помочь не смог, всё что нагуглил с jquery
  • Вопрос задан
  • 247 просмотров
Подписаться 1 Простой Комментировать
Решения вопроса 1
yarkov
@yarkov Куратор тега JavaScript
Помог ответ? Отметь решением.
Так молча )) Взять и обработать событие формы submit. Например так: https://learn.javascript.ru/forms-submit
Ответ написан
Пригласить эксперта
Ответы на вопрос 1
@artem111999000
SEO
Если вы хотите отловить отправку формы не только по нажатию кнопки, но и при нажатии клавиши Enter, вы можете использовать событие "submit" формы и проверить код клавиши события для определения, была ли нажата клавиша Enter. Вот пример кода на ванильном JavaScript:

```javascript
document.addEventListener('DOMContentLoaded', function() {
var form = document.getElementById('myForm'); // Замените 'myForm' на ID вашей формы

form.addEventListener('submit', function(event) {
event.preventDefault(); // Предотвращаем отправку формы по умолчанию

// Выполняйте здесь вашу обработку данных формы перед отправкой

// Пример обработки данных:
var formData = new FormData(form);
var data = {};

for (var pair of formData.entries()) {
data[pair[0]] = pair[1];
}

console.log(data); // Выводим данные формы в консоль (пример)

// Отправляем данные на сервер (AJAX-запрос или другой метод)

// Очищаем форму
form.reset();
});

form.addEventListener('keydown', function(event) {
if (event.key === 'Enter') {
form.dispatchEvent(new Event('submit')); // Имитируем событие submit при нажатии клавиши Enter
}
});
});
```

В этом примере мы добавляем обработчик события "submit" на форму и предотвращаем ее отправку по умолчанию с помощью `event.preventDefault()`. Затем вы можете выполнять вашу обработку данных формы и отправлять данные на сервер. Также мы добавляем обработчик события "keydown" на форму, и если нажата клавиша Enter, мы вызываем событие "submit" формы.

Примечание: Замените `'myForm'` в коде на ID вашей формы, которую вы хотите отслеживать.
Ответ написан
Комментировать
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
Rocket Смоленск
от 80 000 до 130 000 ₽
div. Ставрополь
от 40 000 до 90 000 ₽
Wanted. Санкт-Петербург
До 220 000 ₽
18 дек. 2024, в 16:42
2000 руб./за проект
18 дек. 2024, в 16:33
2000 руб./в час
18 дек. 2024, в 16:06
5000 руб./за проект