Heim > Web-Frontend > js-Tutorial > Wie verhindert man das Absenden eines Formulars beim Drücken der Eingabetaste?

Wie verhindert man das Absenden eines Formulars beim Drücken der Eingabetaste?

Patricia Arquette
Freigeben: 2024-11-08 18:11:02
Original
571 Leute haben es durchsucht

How to Prevent Form Submission on Enter Keypress?

Verhindern der Formularübermittlung beim Drücken der EINGABETASTE

In webbasierten Anwendungen stellt die Verhinderung der Übermittlung der EINGABETASTE an der Übermittlung eines Formulars sicher, dass das Formular nur gesendet wird übermittelt, wenn der Benutzer explizit auf die Schaltfläche „Senden“ klickt. Dieser Ansatz verbessert die Benutzererfahrung und verhindert versehentliche Formularübermittlungen.

Um zu verhindern, dass die Eingabetaste die Formularübermittlung auslöst, können Sie den folgenden Codeausschnitt verwenden:

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;
}
Nach dem Login kopieren

Sobald Sie die definiert haben Wenn Sie die checkEnter-Funktion verwenden, können Sie sie als Tastendruck-Handler an das Formular anhängen:

<form [...] onkeypress="return checkEnter(event)">
Nach dem Login kopieren

Alternativ können Sie Folgendes verwenden ES20xx-Ansatz:

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;
    }
  }
}
Nach dem Login kopieren

Dieser Ansatz nutzt die Ereignisdelegation, um die Formularübermittlung zu verhindern, wenn die EINGABETASTE gedrückt wird, sodass der Benutzer mehrzeiligen Text in Textbereichselementen eingeben kann, ohne eine Übermittlung auszulösen.

Das obige ist der detaillierte Inhalt vonWie verhindert man das Absenden eines Formulars beim Drücken der Eingabetaste?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage