Не удается заставить e.preventDefault работать с React Typescript

У меня есть компонент, который выглядит так:

const App = (): ReactElement => {
    
    const submitFeedbackHandler = (e: FormEvent): void => {
        e.preventDefault();
        // ...
    }

    return <>
        <form onSubmit = {submitFeedbackHandler}>
            // ...
            <button type='submit'>Submit</button>
        </form>
    </>

}

Проблема в том, что как бы я ни пытался вызвать submitFeedbackHandler из onSubmit, это не работает. Я пробовал onSubmit = {(e) => submitFeedbackHandler(e)}, но тоже не повезло. Как я могу заставить это работать, чтобы я мог делать e.preventDefault()?

Страница перезагружается после отправки? Вы получаете какую-либо ошибку проверки типа? FormEvent и ReactElement импортируются?

Julius Guevarra 13.12.2020 00:45

Да, страница перезагружается без ошибок, и да, FormEvent и ReactElement импортируются. Функция submitFeedbackHandler просто не вызывается при отправке формы.

erol_smsr 13.12.2020 00:52

Странно. Он должен работать, как ожидалось. Можете ли вы показать весь компонент, над которым вы работаете? Возможно, в вашем коде есть что-то, что вы не показали, что мешает отправке события.

Julius Guevarra 13.12.2020 01:15

Я нашел проблему. Я добавил required к некоторым вводам в форме. Как ни странно, это полностью останавливает вызов onSubmit. Даже простой вызов () => console.info('onSubmit!') не работал, поэтому я удалил все необходимые теги из полей ввода в формах, и теперь все работает нормально. В этом случае я сам проверю пустые поля, вместо того чтобы полагаться на тег required на входных данных.

erol_smsr 13.12.2020 01:19
Поведение ключевого слова "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
4
2 037
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

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

Это может вызвать головную боль у неопытных разработчиков React, таких как я, поэтому вот ответ на проблему:

Я добавил тег required к некоторым вводам в форме. Как ни странно, это полностью останавливает вызов onSubmit. Даже простой вызов onSubmit = {() => console.info('onSubmit!')} не работал, поэтому я удалил все необходимые теги из полей ввода в форме, и теперь все работает нормально. В этом случае я сам проверю пустые поля, вместо того чтобы полагаться на требуемый тег на входах.

Я думаю, что это связано с контролируемыми и неконтролируемыми компонентами в React. Проведу дальнейшие исследования, чтобы увидеть, что именно вызывает это. Спасибо @Julius Guevarra за вашу помощь.

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