<input type="submit">
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.
<input>
-Elemente des Typs submit
werden als Schaltflächen dargestellt. Wenn das click
Ereignis auftritt (normalerweise, weil der Benutzer auf die Schaltfläche geklickt hat), versucht der User-Agent, das Formular an den Server zu übermitteln.
Wert
Ein <input type="submit">
-Element enthält im value
-Attribut eine Zeichenkette, die als Beschriftung der Schaltfläche angezeigt wird. Schaltflächen haben ansonsten keinen tatsächlichen Wert. Der value
-Attributwert dient als zugängliche Beschreibung der Schaltfläche.
Das value-Attribut festlegen
<input type="submit" value="Send Request" />
Das value-Attribut weglassen
Wenn Sie keinen value
angeben, wird die Schaltfläche eine Standardbeschriftung haben, die vom User-Agent ausgewählt wird. Diese Beschriftung wird wahrscheinlich etwas in der Art von "Submit" oder "Submit Query" sein. Hier ist ein Beispiel für eine Submit-Schaltfläche mit einer Standardbeschriftung in Ihrem Browser:
<input type="submit" />
Zusätzliche Attribute
Zusätzlich zu den Attributen, die alle <input>
-Elemente gemeinsam haben, unterstützen submit
-Button-Eingaben die folgenden Attribute.
formaction
Ein String, der die URL angibt, an die die Daten übermittelt werden sollen. Dies hat Vorrang vor dem action
-Attribut des <form>
Elements, das das <input>
-Element enthält.
Dieses Attribut ist auch für <input type="image">
und <button>
-Elemente verfügbar.
formenctype
Ein String, der die Kodierungsmethode angibt, die beim Übermitteln der Formulardaten an den Server verwendet wird. Es gibt drei erlaubte Werte:
application/x-www-form-urlencoded
-
Dieser, der Standardwert, sendet die Formulardaten als String, nachdem der Text unter Verwendung eines Algorithmus wie
encodeURI()
percent-codiert wurde. multipart/form-data
-
Verwendet die
FormData
API zur Verwaltung der Daten, wodurch Dateien an den Server übermittelt werden können. Sie müssen diesen Kodierungstyp verwenden, wenn Ihr Formular irgendwelche<input>
-Elemente des Typsfile
(<input type="file">
) enthält. text/plain
-
Klartext; hauptsächlich nützlich zum Debuggen, damit Sie die Daten, die übermittelt werden sollen, leicht sehen können.
Wenn angegeben, überschreibt der Wert des formenctype
-Attributs das enctype
-Attribut des besitzenden Formulars.
Dieses Attribut ist auch für <input type="image">
und <button>
-Elemente verfügbar.
formmethod
Ein String, der die HTTP-Methode angibt, die beim Übermitteln der Formulardaten verwendet werden soll; dieser Wert überschreibt jegliches method
-Attribut des besitzenden Formulars. Erlaubte Werte sind:
get
-
Eine URL wird konstruiert, indem mit der von
formaction
oderaction
angegebenen URL begonnen wird, dann ein Fragezeichen-Zeichen ("?") angehängt wird, gefolgt von den Formulardaten, die gemäßformenctype
oder demenctype
-Attribut des Formulars codiert werden. Diese URL wird dann an den Server mittels einer HTTPget
-Anfrage gesendet. Diese Methode eignet sich gut für Formulare, die nur ASCII-Zeichen enthalten und keine Nebeneffekte haben. Dies ist der Standardwert. post
-
Die Formulardaten werden im Body der Anfrage an die von
formaction
oderaction
angegebene URL mittels einer HTTPpost
Methoden gesendet. Diese Methode unterstützt komplexe Daten und Dateianhänge. dialog
-
Mit dieser Methode wird angegeben, dass die Schaltfläche das Dialogfeld schließt, dem das Eingabefeld zugeordnet ist, und die Formulardaten überhaupt nicht übermittelt.
Dieses Attribut ist auch für <input type="image">
und <button>
-Elemente verfügbar.
formnovalidate
Ein Boolean-Attribut, das, wenn es vorhanden ist, angibt, dass das Formular nicht vor der Übermittlung an den Server validiert werden soll. Dies überschreibt den Wert des novalidate
-Attributs des besitzenden Formulars.
Dieses Attribut ist auch für <input type="image">
und <button>
-Elemente verfügbar.
formtarget
Ein String, der einen Namen oder ein Schlüsselwort angibt, der zeigt, wo die Antwort angezeigt wird, nachdem das Formular übermittelt wurde. Der String muss der Name eines Browsing-Kontextes (d.h. ein Tab, Fenster oder <iframe>
) sein. Ein hier angegebener Wert überschreibt das target
-Attribut des <form>
, das dieses Eingabeelement enthält.
Zusätzlich zu den tatsächlichen Namen von Tabs, Fenstern oder Inline-Frames gibt es einige spezielle Schlüsselwörter, die verwendet werden können:
_self
-
Lädt die Antwort in denselben Browsing-Kontext wie den, der das Formular enthält. Dies ersetzt das aktuelle Dokument durch die empfangenen Daten. Dies ist der Standardwert, wenn keiner angegeben ist.
_blank
-
Lädt die Antwort in einen neuen, unbenannten, Browsing-Kontext. Dies ist typischerweise ein neuer Tab im gleichen Fenster wie das aktuelle Dokument, kann sich jedoch abhängig von der Konfiguration des User-Agent unterscheiden.
_parent
-
Lädt die Antwort in den übergeordneten Browsing-Kontext des aktuellen. Wenn es keinen übergeordneten Kontext gibt, verhält sich dies genauso wie
_self
. _top
-
Lädt die Antwort in den obersten Browsing-Kontext; dies ist der Browsing-Kontext, der der oberste Vorfahre des aktuellen Kontexts ist. Wenn der aktuelle Kontext der oberste Kontext ist, verhält sich dies genauso wie
_self
.
Dieses Attribut ist auch für <input type="image">
und <button>
-Elemente verfügbar.
Verwendung von Submit-Schaltflächen
<input type="submit">
-Schaltflächen werden verwendet, um Formulare zu übermitteln. Wenn Sie eine benutzerdefinierte Schaltfläche erstellen und dann das Verhalten mit JavaScript anpassen möchten, müssen Sie <input type="button">
oder besser noch ein <button>
-Element verwenden.
Wenn Sie sich entscheiden, <button>
-Elemente zur Erstellung der Schaltflächen in Ihrem Formular zu verwenden, beachten Sie Folgendes: Wenn sich das <button>
innerhalb eines <form>
befindet, wird diese Schaltfläche als "Submit"-Schaltfläche behandelt. Daher sollten Sie sich angewöhnen, ausdrücklich anzugeben, welche Schaltfläche die Submit-Schaltfläche ist.
Eine einfache Submit-Schaltfläche
Wir beginnen mit der Erstellung eines Formulars mit einer einfachen Submit-Schaltfläche:
<form>
<div>
<label for="example">Let's submit some text</label>
<input id="example" type="text" name="text" />
</div>
<div>
<input type="submit" value="Send" />
</div>
</form>
Dies wird wie folgt gerendert:
Versuchen Sie, etwas Text in das Textfeld einzugeben und dann das Formular abzuschicken.
Beim Absenden werden die Daten-Name/Wert-Paare an den Server gesendet. In diesem Fall wird die Zeichenfolge text=user-text
gesendet, wobei "user-text" der vom Benutzer eingegebene Text ist, der zur Erhaltung spezieller Zeichen codiert wird. Wo und wie die Daten gesendet werden, hängt von der Konfiguration des <form>
ab; siehe Formulardaten senden für weitere Details.
Eine Tastenkombination zu einer Submit-Schaltfläche hinzufügen
Tastenkombinationen, auch als Zugriffstasten und Tastaturäquivalente bekannt, ermöglichen es dem Benutzer, eine Schaltfläche mithilfe einer Taste oder einer Kombination von Tasten auf der Tastatur auszulösen. Um eine Tastenkombination zu einer Submit-Schaltfläche hinzuzufügen – wie Sie es auch bei jedem <input>
tun würden, für das es sinnvoll ist – verwenden Sie das globale Attribut accesskey
.
In diesem Beispiel wird s als Zugriffstaste angegeben (Sie müssen s mit den speziellen Modifikatortasten für Ihre Browser-/OS-Kombination drücken). Um Konflikte mit den Tastenkombinationen des User-Agents zu vermeiden, werden für Zugriffstasten andere Modifikatortasten verwendet als für andere Shortcuts auf dem Host-Computer. Weitere Einzelheiten finden Sie unter accesskey
.
Hier ist das vorherige Beispiel mit der s-Zugriffstaste hinzugefügt:
<form>
<div>
<label for="example">Let's submit some text</label>
<input id="example" type="text" name="text" />
</div>
<div>
<input type="submit" value="Send" accesskey="s" />
</div>
</form>
Zum Beispiel wird in Firefox für Mac, durch das Drücken von Control-Option-S, die Senden-Schaltfläche ausgelöst, während Chrome auf Windows Alt+S verwendet.
Das Problem mit dem obigen Beispiel ist, dass der Benutzer nicht wissen wird, was die Zugriffstaste ist! Dies ist besonders dann der Fall, wenn die Modifikatortasten normalerweise nicht standardisiert sind, um Konflikte zu vermeiden. Wenn Sie eine Website erstellen, stellen Sie sicher, dass Sie diese Informationen auf eine Weise bereitstellen, die das Design der Seite nicht beeinträchtigt (zum Beispiel durch Bereitstellung eines leicht zugänglichen Links, der auf Informationen zu den Zugriffstasten der Seite verweist). Das Hinzufügen eines Tooltips zur Schaltfläche (mithilfe des title
-Attributs) kann ebenfalls hilfreich sein, ist jedoch keine vollständige Lösung für Zugänglichkeitsprobleme.
Eine Submit-Schaltfläche deaktivieren und aktivieren
Um eine Submit-Schaltfläche zu deaktivieren, geben Sie das disabled
-Attribut darauf an, wie folgt:
<input type="submit" value="Send" disabled />
Sie können Schaltflächen zur Laufzeit aktivieren und deaktivieren, indem Sie disabled
auf true
oder false
setzen; in JavaScript sieht das so aus: btn.disabled = true
oder btn.disabled = false
.
Hinweis:
Weitere Ideen zum Aktivieren und Deaktivieren von Schaltflächen finden Sie auf der <input type="button">
-Seite.
Validierung
Submit-Schaltflächen nehmen nicht an der Constraint-Validierung teil; sie haben keinen tatsächlichen Wert, der eingeschränkt werden könnte.
Beispiele
Wir haben oben grundlegende Beispiele eingefügt. Es gibt wirklich nicht viel mehr über Submit-Schaltflächen zu sagen. Es gibt einen Grund, warum diese Art von Steuerung manchmal als "einfache Schaltfläche" bezeichnet wird.
Technische Zusammenfassung
Wert | Eine Zeichenkette, die als Beschriftung der Schaltfläche verwendet wird |
Ereignisse | [`click`](/de/docs/Web/API/Element/click_event) |
Unterstützte allgemeine Attribute |
type und
value
|
IDL-Attribute | value |
DOM-Schnittstelle | [`HTMLInputElement`](/de/docs/Web/API/HTMLInputElement) |
Methoden | Keine |
Implizite ARIA-Rolle | button |
Spezifikationen
Specification |
---|
HTML # submit-button-state-(type=submit) |
Browser-Kompatibilität
BCD tables only load in the browser
Siehe auch
<input>
und dieHTMLInputElement
-Schnittstelle, die es implementiert.- Formulare und Schaltflächen
- HTML-Formulare
- Das
<button>
-Element