Heim > Artikel > Web-Frontend > Wie verhindert man unerwünschte Formularübermittlungen beim Drücken der EINGABETASTE in Webanwendungen?
In webbasierten Anwendungen kann das versehentliche Absenden von Formularen, das durch die EINGABETASTE ausgelöst wird, ein Ärgernis sein. Dieser Leitfaden bietet Lösungen, um ein solches unerwünschtes Verhalten zu verhindern.
Ein benutzerdefinierter Tastendruck-Handler kann für das Formular implementiert werden, um den Tastendruck der EINGABETASTE abzufangen und das Absenden des Formulars für alle zu verhindern Elemente außer Textbereichen.
function checkEnter(e) { e = e || event; var txtArea = /textarea/i.test((e.target || e.srcElement).tagName); return txtArea || (e.keyCode || e.which || e.charCode || 0) !== 13; } document.querySelector('form').onkeypress = checkEnter;
Ein modernerer Ansatz mit Ereignisdelegation kann für die Verarbeitung von ENTER-Pressen verwendet werden. Bei diesem Ansatz wird das Ereignis auf Dokumentebene erfasst und nach dem nächstgelegenen Formularvorfahren gesucht. Nur gekennzeichnete Elemente mit dem Attribut „Dateneingabe zur Übermittlung“ lösen die Übermittlung des Formulars bei Eingabe der EINGABETASTE aus.
document.addEventListener(`keypress`, handle); function handle(evt) { const form = evt.target.closest(`#testForm`); if (form) { if (evt.target.dataset.enterForSubmit) { if (evt.key === `Enter`) { evt.preventDefault(); return logClear(`won't submit "${evt.target.value}"`); } return true; } } }
Das obige ist der detaillierte Inhalt vonWie verhindert man unerwünschte Formularübermittlungen beim Drücken der EINGABETASTE in Webanwendungen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!