Как заставить работать функцию отправки в Javascript?

Айо,

Я немного борюсь с функциями в JS. Идея состоит в том, что после того, как пользователь нажимает кнопку отправки, он проверяет, заполнены ли все обязательные поля, и если да, то запускает анимацию загрузки. Анимация загрузки должна быть индикатором состояния во время отправки формы и перенаправления на страницу успеха.

Я пытался использовать функцию onsubmit в HTML-теге формы, но это не сработало. Важно то, что это произойдет, если обязательные поля будут заполнены.

Спасибо

JS

const submit_btn = document.querySelector('.submit-btn')

function loading() {
  this.innerHTML = "<div class='loader'></div>"
}

HTML

<form
  onsubmit = "loading()" 
  action = "https://formsubmit.co/2007080c2cf8bd2ebb68506e7aa98c5f"
  method = "POST"
  enctype = "multipart/form-data"
>

Я пытался использовать функцию onsubmit в HTML-теге формы, но это не сработало.

Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
В настоящее время производительность загрузки веб-сайта имеет решающее значение не только для удобства пользователей, но и для ранжирования в...
Безумие обратных вызовов в javascript [JS]
Безумие обратных вызовов в javascript [JS]
Здравствуйте! Юный падаван 🚀. Присоединяйся ко мне, чтобы разобраться в одной из самых запутанных концепций, когда вы начинаете изучать мир...
Система управления парковками с использованием HTML, CSS и JavaScript
Система управления парковками с использованием HTML, CSS и JavaScript
Веб-сайт по управлению парковками был создан с использованием HTML, CSS и JavaScript. Это простой сайт, ничего вычурного. Основная цель -...
JavaScript Вопросы с множественным выбором и ответы
JavaScript Вопросы с множественным выбором и ответы
Если вы ищете платформу, которая предоставляет вам бесплатный тест JavaScript MCQ (Multiple Choice Questions With Answers) для оценки ваших знаний,...
1
0
55
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Что касается валидации:

Вы можете использовать Constrained Validation API (см. MDN), чтобы проверить, все ли поля заполнены. Обычно вы хотите использовать его после того, как пользователь отправил <form>, но до отправки формы на сервер.

Это достижимо, используя его внутри обработчика событий, который вызывается при submit тинге формы.

Что касается обработки событий:

Чтобы реализовать описанный выше механизм, вам нужно добавить прослушиватель событий к событию submit формы через .addEventListener() вместо атрибута onsubmit. Таким образом, вы получите объект event в качестве аргумента функции обработчика событий, с помощью которой вы можете предотвратить отправку формы.

Пример:

const myForm = document.querySelector('form'); // or '#myform', etc...

// define the event handler function
function onFormSubmission(event) {
  const fields = Array.from(event.target.elements);
  const allValid = fields.every(field => field.reportValidity()); 
  if (!allValid) {
    event.preventDefault(); // stop form submission
    return;
  }
  event.target.innerHTML = '<div class = "loading"></div>';
}

// add an event listener that fires on submission
myForm.addEventListener('submit', onFormSubmission);
<form id = "myform" action = "path/to/backend/script.php" method = "POST" enctype = "multipart/formdata" novalidate>
  <input type = "text" name = "foo" placeholder = "I am required!" required>
  <hr>
  <button type = "submit">Submit form</button>
</form>

РЕДАКТИРОВАТЬ

Извините, я пропустил добавление части, которая отображает информацию/элемент загрузки. Добавлено (хотя на самом деле вы его не увидите, потому что, если все обязательные поля заполнены, форма будет отправлена, что приведет к обновлению страницы. Вам понадобится что-то вроде XHR или аналогичного, но это не объем вопроса).

Потрясающе, Дэвид. Я разобрался с вашим кодом. Большое спасибо, чувак, я ценю твое время!!

Adam 15.11.2022 21:19

Другие вопросы по теме