Heim > Web-Frontend > js-Tutorial > Wie kann ich zwei Formulare gleichzeitig mit einer einzigen Schaltfläche senden?

Wie kann ich zwei Formulare gleichzeitig mit einer einzigen Schaltfläche senden?

Barbara Streisand
Freigeben: 2024-11-26 01:07:11
Original
274 Leute haben es durchsucht

How Can I Submit Two Forms Simultaneously with a Single Button?

Zwei Formulare mit einer einzigen Schaltfläche senden

Das Senden von zwei Formularen mit einer Schaltfläche mag wie eine einfache Aufgabe erscheinen, ist aber mit herkömmlichen Methoden nicht möglich Formularübermittlungsmethoden. Dies liegt daran, dass beim Absenden eines Formulars von der aktuellen Seite weg zu der im Formular angegebenen Aktion navigiert wird.

Die Lösung: Asynchrone Formularübermittlung

Um beide Formulare gleichzeitig einzureichen, Wir müssen den traditionellen Prozess der Formularübermittlung umgehen. Wir können dies erreichen, indem wir das erste Formular asynchron über JavaScript senden, sodass wir das zweite Formular senden können, ohne das erste zu beeinträchtigen.

Asynchrone Formularübermittlung mit JavaScript:

Die Der folgende JavaScript-Code zeigt, wie das erste Formular asynchron übermittelt wird:

var f = document.forms.updateDB;
var postData = [];
for (var i = 0; i < f.elements.length; i++) {
    postData.push(encodeURIComponent(f.elements[i].name) + "=" +
        encodeURIComponent(f.elements[i].value));
}
var xhr = new XMLHttpRequest();
xhr.open("POST", "mypage.php", true);
xhr.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
xhr.send(postData.join("&"));
Nach dem Login kopieren

Sobald das erste Formular asynchron übermittelt wird, können wir es tun Senden Sie sofort das zweite Formular mit der Standard-Formular-Submit()-Methode:

document.forms.payPal.submit();
Nach dem Login kopieren

Aktualisierte Lösung (2023):

Die aktualisierte Lösung nutzt fetch() und modern JavaScript-Syntax:

function submitBothForms() {
    const { updateDB, payPal } = document.forms;
    fetch(updateDB.action, {
        method: updateDB.method,
        headers: { "content-type": updateDB.enctype },
        body: new FormData(updateDB),
    });

    payPal.submit();
}
Nach dem Login kopieren

Diese aktualisierte Lösung bietet eine präzisere und leistungsfähigere Implementierung im Vergleich zur ursprünglichen Antwort.

Das obige ist der detaillierte Inhalt vonWie kann ich zwei Formulare gleichzeitig mit einer einzigen Schaltfläche senden?. 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