Verhindern Sie, dass Benutzer ein Formular senden, indem Sie die Eingabetaste drücken

773

Ich habe eine Umfrage auf einer Website und es scheint einige Probleme mit den Benutzern zu geben, die die Eingabetaste drücken (ich weiß nicht warum) und versehentlich die Umfrage (Formular) senden, ohne auf die Schaltfläche "Senden" zu klicken. Gibt es eine Möglichkeit, dies zu verhindern?

Ich verwende HTML, PHP 5.2.9 und jQuery für die Umfrage.

DForck42
quelle
2
Verwenden Sie keine Formular-Tags und führen Sie keine benutzerdefinierten Ajax-Anfragen aus :) Aber sicher, Sie können mit dem Ansatz des Abhörens und Verhinderns von Schlüsseln
fortfahren
Ich verwende die Formular-Tags einfach nicht, weil ich es vorziehe, Formulare auf unkonventionelle Weise über Ajax-Anforderungen zu verarbeiten (z. B. das Senden einiger Felder, wenn deren Fokus gelöscht wird usw.). Sie können auch einen speziellen Listener erstellen, um die Eingabetaste abzufangen und nur zu verarbeiten, wenn Sie dies möchten.
Juan

Antworten:

881

Sie können eine Methode wie verwenden

$(document).ready(function() {
  $(window).keydown(function(event){
    if(event.keyCode == 13) {
      event.preventDefault();
      return false;
    }
  });
});

EnterWenn Sie die Kommentare zum Originalbeitrag lesen, um ihn benutzerfreundlicher zu gestalten und den Benutzern das Drücken zu ermöglichen, wenn sie alle Felder ausgefüllt haben:

function validationFunction() {
  $('input').each(function() {
    ...

  }
  if(good) {
    return true;
  }
  return false;
}

$(document).ready(function() {
  $(window).keydown(function(event){
    if( (event.keyCode == 13) && (validationFunction() == false) ) {
      event.preventDefault();
      return false;
    }
  });
});
Peter Mortensen
quelle
7
Ich bin derzeit nur auf der Suche nach einer schnellen Lösung und habe keine Zeit, Validierungselemente zu implementieren. Ich schätze die Antworten aller, aber dies ist die, mit der ich in der Zwischenzeit gehen werde. Vielen Dank.
DForck42
8
Diese Methode ist unideal, da sie verhindert, dass der Benutzer das Formular durch Drücken der Eingabetaste sendet, während er sich auf die Schaltfläche zum Senden konzentriert. Die beste Lösung wäre die von BalusC unten, bei der die Eingabe nur unterbrochen wird, während der Schwerpunkt weiterhin auf den Formulareingaben liegt.
Anson Kao
3
Ich habe Situationen gesehen (nur Internet Explorer), in denen Sie sich keydownan das documentanstatt an das binden müssen, windowdamit dies funktioniert.
MartinHN
8
Möglicherweise möchten Sie && !$(document.activeElement).is('textarea')der Bedingung hinzufügen , oder Zeilenumbrüche in einem Textbereich werden blockiert (zumindest im IE).
Flash
1
Das funktioniert bei mir. Dies verhindert jedoch auch das Hinzufügen einer Unterbrechungslinie im Textbereich.
César León
613

Geben Sie die Eingabetaste an keiner Stelle ein

Wenn Sie keine <textarea>in Ihrem Formular haben, fügen Sie einfach Folgendes zu Ihrem hinzu <form>:

<form ... onkeydown="return event.key != 'Enter';">

Oder mit jQuery:

$(document).on("keydown", "form", function(event) { 
    return event.key != "Enter";
});

Dies führt dazu, dass jeder Tastendruck im Formular auf dem überprüft wird key. Wenn dies nicht der Fall ist Enter, wird es zurückkehren trueund alles wird wie gewohnt fortgesetzt. Wenn dies der Fall ist Enter, wird es zurückgegeben falseund alles wird sofort gestoppt, sodass das Formular nicht gesendet wird.

Die keydownVeranstaltung wird der Veranstaltung vorgezogen, keyupda keyupes zu spät ist, die Formularübermittlung zu blockieren. Historisch gab es auch die keypress, aber diese ist veraltet, ebenso wie die KeyboardEvent.keyCode. Sie sollten KeyboardEvent.keystattdessen verwenden, was den Namen der gedrückten Taste zurückgibt. Wenn Enterdiese Option aktiviert ist, werden sowohl 13 (normale Eingabe) als auch 108 (Numpad-Eingabe) überprüft.

Beachten Sie, dass, $(window)wie in einigen anderen Antworten vorgeschlagen, $(document)nicht für keydown/ keyupin IE <= 8 funktioniert. Dies ist also keine gute Wahl, wenn Sie auch diese armen Benutzer abdecken möchten.

Eingabetaste nur in Textbereichen zulassen

Wenn Sie eine <textarea>in Ihrem Formular haben (die natürlich die Eingabetaste akzeptieren sollte ), fügen Sie den Keydown-Handler zu jedem einzelnen Eingabeelement hinzu, das keine ist <textarea>.

<input ... onkeydown="return event.key != 'Enter';">
<select ... onkeydown="return event.key != 'Enter';">
...

Um die Boilerplate zu reduzieren, ist dies besser mit jQuery zu tun:

$(document).on("keydown", ":input:not(textarea)", function(event) {
    return event.key != "Enter";
});

Wenn an diese Eingabeelemente andere Ereignishandlerfunktionen angehängt sind, die Sie aus irgendeinem Grund auch bei der Eingabetaste aufrufen möchten, verhindern Sie nur das Standardverhalten des Ereignisses, anstatt false zurückzugeben, damit es ordnungsgemäß an andere Handler weitergegeben werden kann.

$(document).on("keydown", ":input:not(textarea)", function(event) {
    if (event.key == "Enter") {
        event.preventDefault();
    }
});

Lassen Sie die Eingabetaste in Textbereichen zu und senden Sie nur Schaltflächen

Wenn Sie die Eingabetaste auch für die Senden-Schaltflächen zulassen möchten <input|button type="submit">, können Sie die Auswahl jederzeit wie folgt verfeinern.

$(document).on("keydown", ":input:not(textarea):not(:submit)", function(event) {
    // ...
});

Beachten Sie, dass, input[type=text]wie in einigen anderen Antworten vorgeschlagen, diese HTML5-Nicht-Texteingaben nicht behandelt werden. Dies ist also keine gute Auswahl.

BalusC
quelle
11
Dies sollte die gute Antwort sein, da es sich auch um Form einschließlich Textbereich handelt und die Ereignisausbreitung besser erklärt
foobar
6
":input:not(textarea):not([type=submit]):not(button)"wenn Sie <button>anstelle von<input type=submit>
Simon_Weaver
Dies verhindert, dass die Eingabetaste für andere Eingaben als den Textbereich funktioniert. Es ist keine gute Lösung
mate.gwozdz
Soll es vorher einen Doppelpunkt geben input?
xfactorial
1
@ YodaDaCoda: vereinbart und angepasst.
BalusC
110

In Abschnitt 4.10.22.2 Implizite Übermittlung der W3C-HTML5-Spezifikation heißt es:

formDie Standardschaltfläche eines Elements ist die erste Übermittlungsschaltfläche in der Baumreihenfolge, deren Formularbesitzer dieses formElement ist.

Wenn der Benutzeragent unterstützt, dass der Benutzer ein Formular implizit senden kann (z. B. wenn auf einigen Plattformen die Eingabetaste gedrückt wird, während ein Textfeld fokussiert ist, wird das Formular implizit gesendet), gilt dies für ein Formular, dessen Standardschaltfläche eine definierte Aktivierung aufweist Das Verhalten muss dazu führen, dass der Benutzeragent Schritte zur Aktivierung synthetischer Klicks auf dieser Standardschaltfläche ausführt .

Hinweis: Wenn die Standardschaltfläche deaktiviert ist, wird das Formular nicht gesendet, wenn ein solcher impliziter Übermittlungsmechanismus verwendet wird. (Eine Schaltfläche hat kein Aktivierungsverhalten, wenn sie deaktiviert ist.)

Eine standardkonforme Möglichkeit zum Deaktivieren der impliziten Übermittlung des Formulars besteht daher darin, eine deaktivierte Übermittlungsschaltfläche als erste Übermittlungsschaltfläche im Formular zu platzieren:

<form action="...">
  <!-- Prevent implicit submission of the form -->
  <button type="submit" disabled style="display: none" aria-hidden="true"></button>

  <!-- ... -->

  <button type="submit">Submit</button>
</form>

Ein schönes Merkmal dieses Ansatzes ist, dass er ohne JavaScript funktioniert . Unabhängig davon, ob JavaScript aktiviert ist oder nicht, ist ein standardkonformer Webbrowser erforderlich, um die implizite Übermittlung von Formularen zu verhindern.

Daniel Trebbien
quelle
6
Errrr ... Das ist massives Gold. Wenn dies wirklich browserübergreifend funktioniert, verdient es, nach oben zu gehen! Wie können so viele Menschen mit Variationen von Tastendruck, Tastendruck usw. geantwortet haben, aber diese auf Standards basierende Antwort verpasst haben?
John Rees
4
Einerseits ist es einfach und verhindert alle Fallstricke, die durch die akzeptierten Antworten vorgeschlagen werden. Auf der anderen Seite fühlt es sich wie eine leichte Ausnutzung des Standards an. Ein großes Lob für die Aufnahme des Attributs aria- *. Ich würde gerne mehr Feedback dazu hören.
Solvitieg
2
Funktioniert auch als <input type="submit" disabled style="display: none" aria-hidden="true" />und Sie können die Größe Ihrer Seite um einige Zeichen reduzieren. :-P
Gaefan
7
IE 11 reicht trotzdem ein.
CamaroSS
2
Safari ist der neue IE.
Twistedpixel
68

Ich musste alle drei Ereignisse im Zusammenhang mit dem Drücken von Tasten abfangen, um zu verhindern, dass das Formular gesendet wurde:

    var preventSubmit = function(event) {
        if(event.keyCode == 13) {
            console.log("caught ya!");
            event.preventDefault();
            //event.stopPropagation();
            return false;
        }
    }
    $("#search").keypress(preventSubmit);
    $("#search").keydown(preventSubmit);
    $("#search").keyup(preventSubmit);

Sie können all das zu einer schönen kompakten Version kombinieren:

    $('#search').bind('keypress keydown keyup', function(e){
       if(e.keyCode == 13) { e.preventDefault(); }
    });
Upgradingdave
quelle
7
Sie können entweder die letzten 3 Selektoren verketten oder mehrere Ereignisse mit einer solchen Methode binden $("#search").bind('keypress keyup keydown',preventSubmit).
Moak
Da in einer ASP.NET Web - Formular alles in einem verschachtelt werden muss <form>Tag, die Enter - Taste wird das Formular ... Diese Lösung die Enter - Taste deaktiviert und das Problem behoben aber dank @ Dave! Dann habe ich die Eingabetaste für bestimmte Felder durch aktiviert id.
Ian Campbell
@Upgradingdave Wie können Sie "log ()" anstelle von "console.log ()" schreiben?
Radbyx
1
@radbyx ... guter Fang, es sollte sein console.log, ich habe meine Antwort aktualisiert.
Upgradingdave
Beachten Sie, dass keypress keyup keydownSie mit jedem Code in der if-Bedingung zweimal auslösen .
Kai Noack
56

Wenn Sie ein Skript verwenden, um die eigentliche Übermittlung durchzuführen, können Sie dem Onsubmit-Handler die folgende Zeile "return false" hinzufügen:

<form onsubmit="return false;">

Das Aufrufen von submit () im Formular über JavaScript löst das Ereignis nicht aus.

Tom Hubbard
quelle
Funktioniert für mich in Chrome. Dadurch werden auch die Senden-Schaltflächen deaktiviert. Dies ist in Ordnung, wenn Sie ein Onlick-Ereignis für die Senden-Schaltfläche selbst auslösen möchten. Ajax-Hinweis: Fügen Sie Ihren Funktionsaufruf vor der Rückkehr hinzu, und der Benutzer kann weiterhin die Eingabetaste drücken, ohne das Formular an die Seite zu senden.
Dennis Heiden
Arbeitete für mich unter Chrome, IE-11 und Firefox und war die am einfachsten zu implementierende Lösung. Das Deaktivieren der Eingabetaste in ganzen Abschnitten der Seite, wie es einige Antworten tun, scheint zu extrem und anfällig für Fehler zu sein.
Roberto
Vielen Dank. es hat bei mir funktioniert.
LU
23

Verwenden:

$(document).on('keyup keypress', 'form input[type="text"]', function(e) {
  if(e.keyCode == 13) {
    e.preventDefault();
    return false;
  }
});

Diese Lösung funktioniert auf allen Formularen auf einer Website (auch auf mit Ajax eingefügten Formularen) und verhindert nur Enters in Eingabetexten. Platzieren Sie es in einer dokumentenbereiten Funktion und vergessen Sie dieses Problem ein Leben lang.

Buzogany Laszlo
quelle
Ich denke, die ursprüngliche Antwort e.whichwar in Ordnung; keine Notwendigkeit, es zu ändern e.keyCode. Beide geben den Wert 13 für die Eingabetaste zurück. Siehe stackoverflow.com/a/4471635/292060 und stackoverflow.com/a/18184976/292060
goodeye
2
Diese Lösung kümmert sich um zwei Lösungen: 1.)
Senden
21

Anstatt zu verhindern, dass Benutzer drücken Enter, was unnatürlich erscheint, können Sie das Formular unverändert lassen und eine zusätzliche clientseitige Validierung hinzufügen: Wenn die Umfrage nicht abgeschlossen ist, wird das Ergebnis nicht an den Server gesendet und der Benutzer erhält eine nette Nachricht Was muss ausgefüllt werden, um das Formular auszufüllen? Wenn Sie jQuery verwenden, versuchen Sie es mit dem Validierungs-Plugin:

http://docs.jquery.com/Plugins/Validation

Dies erfordert mehr Arbeit als das Abfangen der EnterSchaltfläche, bietet aber sicherlich eine umfassendere Benutzererfahrung.

bbmud
quelle
13
Das hört sich gut an, aber optionale Felder sind problematisch. Der Benutzer kann versehentlich die Eingabetaste drücken und das Formular wird gesendet. Ich sehe nicht, wie Sie wissen werden, wenn die Umfrage nicht abgeschlossen ist, es sei denn, Sie setzen jedes Feld wie erforderlich (keine Standardauswahl, keine leeren Felder erlaubt ...)
Christophe Roussy
19

Eine schöne einfache kleine jQuery-Lösung:

$("form").bind("keypress", function (e) {
    if (e.keyCode == 13) {
        return false;
    }
});
Eonasdan
quelle
1
+1 Ich suchte nach einer jQuery-Alternative, anstatt normales JS wievar key = event.keyCode || event.which; if (key == 13) return false;
RaphaelDDL
1
Technisch gesehen ist dies immer noch POJ, nur mit einem einfacheren JQuery-Wrapper. Der Code, den Sie gegeben haben, ist fast dasselbe.
Eonasdan
19

Ich kann noch keinen Kommentar abgeben, daher werde ich eine neue Antwort veröffentlichen

Die akzeptierte Antwort ist in Ordnung, aber sie hat das Senden bei der Eingabe des Nummernblocks nicht gestoppt. Zumindest in der aktuellen Version von Chrome. Ich musste die Keycode-Bedingung ändern, dann funktioniert es.

if(event.keyCode == 13 || event.keyCode == 169) {...}
sparklos
quelle
5
Der Unterschied zwischen Eingabe und Rückgabe - viele Point-of-Sales-Betreiber verwenden ausschließlich das Nummernfeld. +1
helloserve
8
Jetzt (21.05.2015) ist keyCode sowohl für die normale Eingabe als auch für die Numpad-Eingabe 13 [Chrome 42, IE 11, FIreFox 36]
Cliff Burton
15

Es ist meine Lösung, um das Ziel zu erreichen, es ist sauber und effektiv.

$('form').submit(function () {
  if ($(document.activeElement).attr('type') == 'submit')
     return true;
  else return false;
});
Entwickler
quelle
13

Ein ganz anderer Ansatz:

  1. Der erste <button type="submit">im Formular wird beim Drücken aktiviert Enter.
  2. Dies gilt auch dann, wenn die Schaltfläche mit ausgeblendet ist style="display:none;
  3. Das Skript für diese Schaltfläche kann zurückgegeben werden false, wodurch der Übermittlungsprozess abgebrochen wird.
  4. Sie können <button type=submit>das Formular noch von einem anderen senden lassen. Kehren Sie einfach zurück, trueum die Einreichung zu kaskadieren.
  5. Durch Drücken, Enterwährend die reale Senden-Taste fokussiert ist, wird die echte Senden-Schaltfläche aktiviert.
  6. Das Drücken Enterinnerhalb <textarea>oder anderer Formularsteuerelemente verhält sich wie gewohnt.
  7. Durch Drücken Enterinnerhalb <input>Formularsteuer löst der erste <button type=submit>, der zurückkehrt false, und damit nichts passiert.

Somit:

<form action="...">
  <!-- insert this next line immediately after the <form> opening tag -->
  <button type=submit onclick="return false;" style="display:none;"></button>

  <!-- everything else follows as normal -->
  <!-- ... -->
  <button type=submit>Submit</button>
</form>
Erics
quelle
1
Hmm, in Chrome und Firefox wäre eine noch kürzere Version <button disabled style = "display: none;"> <button>, was auch den Vorteil hat, dass JS nicht funktionieren muss. Safari ignoriert einfach die Schaltfläche und so passieren andere Dinge wie gewohnt.
Erics
1
Ich mochte den Weg "13 Schlüsselcode ignorieren" wirklich nicht, also fing ich an, über einen einfachen und kniffligen Weg nachzudenken, und diese Idee kam mir in den Sinn und als ich diese Seite nach unten scrollte, sah ich diesen Thread :). Plus eins für gegenseitige Idee und natürlich die beste Lösung.
Jalali Shakib
Perfekte Antwort für mich. Ich wollte ein Formular, um eine CLI zu emulieren, damit der Benutzer für jedes nächste Feld die Eingabetaste drückt und am Ende eine Übermittlung erhält.
Nathan
oh brillant, der letzte Knopf kann so sein, um zu verhindern, dass Duplikate mit schnellen Klicks <button onclick="this.disabled=true;this.form.submit();" type="submit"">submit</button>
eingereicht werden
@ArashMoosapour Bitte deaktivieren Sie die Senden-Schaltflächen nicht, wenn sie den Fokus haben. Dadurch wird der Fokus gelöscht und die Zugänglichkeit wird beeinträchtigt.
Erics
9

Geben Sie der Form eine Aktion von 'Javascript: void (0);' scheint den Trick zu tun

<form action="javascript:void(0);">
<input type="text" />
</form>
<script>
$(document).ready(function() {
    $(window).keydown(function(event){
        if(event.keyCode == 13) {
    alert('Hello');
        }
    });
});
</script>
Sidarcy
quelle
8

Das Nicht-Setzen eines Submit-Buttons könnte reichen. Fügen Sie einfach ein Skript in die Eingabe ein (Typ = Schaltfläche) oder fügen Sie eventListener hinzu, wenn Sie möchten, dass die Daten im Formular gesendet werden.

Verwenden Sie dies lieber

<input type="button">

als dies zu verwenden

<input type="submit">
Jimwel Anobong
quelle
8
  1. Verwenden Sie nicht type = "submit" für Eingaben oder Schaltflächen.
  2. Verwenden Sie type = "button" und verwenden Sie js [Jquery / angle / etc], um das Formular an den Server zu senden.
Irfan Ashraf
quelle
7

Ich musste verhindern, dass nur bestimmte Eingaben gesendet wurden, daher habe ich einen Klassenselektor verwendet, damit dies eine "globale" Funktion ist, wo immer ich sie benötige.

<input id="txtEmail" name="txtEmail" class="idNoEnter" .... />

Und dieser jQuery-Code:

$('.idNoEnter').keydown(function (e) {
  if (e.keyCode == 13) {
    e.preventDefault();
  }
});

Alternativ, wenn der Keydown nicht ausreicht:

$('.idNoEnter').on('keypress keydown keyup', function (e) {
   if (e.keyCode == 13) {
     e.preventDefault();
   }
});

Einige Notizen:

Wenn Sie hier verschiedene gute Antworten ändern, Enterscheint der Schlüssel für keydownalle Browser zu funktionieren . Für die Alternative habe ich bind()auf die on()Methode aktualisiert .

Ich bin ein großer Fan von Klassenselektoren, die alle Vor- und Nachteile sowie Leistungsdiskussionen abwägen. Meine Namenskonvention lautet "idSomething", um anzuzeigen, dass jQuery sie als ID verwendet, um sie vom CSS-Stil zu trennen.

Gutes Auge
quelle
Dies funktioniert für die Textfeldelemente im Formular. Während Sie eingeben und in das Textfeld die Eingabetaste drücken, wird das Formular vom Standardverhalten gesendet. Dies fängt die Eingabetaste ab und verhindert, dass sie gesendet wird.
Goodeye
5

Sie können eine JavaScript-Methode erstellen, um zu überprüfen, ob der EnterSchlüssel gedrückt wurde, und um die Übermittlung zu stoppen.

<script type="text/javascript">
  function noenter() {
  return !(window.event && window.event.keyCode == 13); }
</script>

Rufen Sie das einfach bei der Submit-Methode auf.

Brandon
quelle
4

NUR BLOCK SUBMIT, aber keine andere wichtige Funktion der Eingabetaste, z. B. das Erstellen eines neuen Absatzes in einem <textarea>:

window.addEventListener('keydown', function(event) {
  //set default value for variable that will hold the status of keypress
  pressedEnter = false;

  //if user pressed enter, set the variable to true
  if (event.keyCode == 13)
    pressedEnter = true;

  //we want forms to disable submit for a tenth of a second only
  setTimeout(function() {
    pressedEnter = false;
  }, 100)

})

//find all forms
var forms = document.getElementsByTagName('form')

//loop through forms
for (i = 0; i < forms.length; i++) {
  //listen to submit event
  forms[i].addEventListener('submit', function(e) {
    //if user just pressed enter, stop the submit event
    if (pressedEnter == true) {
      updateLog('Form prevented from submit.')
      e.preventDefault();
      return false;
    }

    updateLog('Form submitted.')
  })
}

var log = document.getElementById('log')
updateLog = function(msg) {
  log.innerText = msg
}
input,
textarea {
  display: inline-block;
  margin-bottom: 1em;
  border: 1px solid #6f6f6f;
  padding: 5px;
  border-radius: 2px;
  width: 90%;
  font-size: 14px;
}

input[type=submit] {
  background: lightblue;
  color: #fff;
}
<form>
  <p>Sample textarea (try enter key):</p>
  <textarea rows="4">Hit enter, a new line will be added. But the form won't submit</textarea><br/>
  <p>Sample textfield (try enter key):</p>
  <input type="text" placeholder="" />
  <br/>
  <input type="submit" value="Save" />
  <h3 id="log"></h3>
</form>

mate.gwozdz
quelle
Ich frage mich, wer und warum dies ablehnen würde: | Was ist das Problem mit meiner Lösung?
mate.gwozdz
Für den Beitrag positiv bewertet. Die akzeptierte Antwort unterbricht die meisten Formulare der Benutzeroberfläche und verhindert, dass "Enter" für die gesamte Anwendung registriert wird. Nicht gut. Ich denke, es ist eine gute Idee, die Eingabe in Formularelementen, insbesondere Schaltflächen, zuzulassen, damit mir der Pfad gefällt, den Sie gehen. Ich denke, dass dies ohne Zeitüberschreitung erreicht werden kann. Schauen Sie sich zum Beispiel einfach das Elementattribut in Ihrem Ereignishandler an. Erlaube 'button' und '
submit
@ NathanCH - Dieser Code macht genau das Gegenteil von dem, was Sie sagen. Es verhindert nur, dass die Eingabe das Formular sendet, und verhindert keine anderen Funktionen. Beispielsweise haben Sie möglicherweise ein Textfeld und möchten die Eingabe verwenden, um neue Absätze zu erstellen.
mate.gwozdz
1
In der ersten Zeile steht ein Tippfehler. Stattdessen function(e)sollte es sein function(event). Ansonsten funktioniert es bei mir. Vielen Dank.
Guillermo Prandi
1
Dies ist ein absoluter Lebensretter, da alles andere mich daran hindert, Eingabeereignisse für Dinge wie Raster-Inline-Änderungen ordnungsgemäß zu verarbeiten. Der einzige Vorschlag ist, 'setTimeout' überhaupt nicht zu verwenden. Ich denke, das ist das Problem, das die Leute mit dieser Antwort haben. Es ist zu pingelig. Stattdessen stellen Sie für das Ereignis do on("keydown", function(event) { enterPressed = true; }und dann im Submit-Ereignis do on("submit", function(e) { if (pressedEnter == true) { pressedEnter = false; e.preventDefault(); return false;}sicher, dass es unabhängig von der Verzögerung funktioniert.
Curtis Snowden
3

Dies ist der perfekte Weg. Sie werden nicht von Ihrer Seite weitergeleitet

$('form input').keydown(function (e) {
if (e.keyCode == 13) {
    e.preventDefault();
    return false;
}
});
Rifkan Razak
quelle
2

Ich hatte ein ähnliches Problem, bei dem ich ein Raster mit "Ajax-Textfeldern" (Yii CGridView) und nur einer Senden-Schaltfläche hatte. Jedes Mal, wenn ich in einem Textfeld gesucht und das übermittelte Formular eingegeben habe. Ich musste etwas mit der Schaltfläche tun, da dies die einzige gemeinsame Schaltfläche zwischen den Ansichten war (MVC-Muster). Alles was ich tun musste war entfernen type="submit"und setzenonclick="document.forms[0].submit()

StackUnder
quelle
2

Ich denke, es ist mit allen Antworten gut abgedeckt, aber wenn Sie eine Schaltfläche mit einem JavaScript-Validierungscode verwenden, können Sie einfach den Onkeypress des Formulars für Enter festlegen, um Ihre Übermittlung wie erwartet aufzurufen:

<form method="POST" action="..." onkeypress="if(event.keyCode == 13) mySubmitFunction(this); return false;">

Der Onkeypress JS könnte alles sein, was Sie tun müssen. Es besteht keine Notwendigkeit für eine größere globale Veränderung. Dies gilt insbesondere dann, wenn Sie nicht derjenige sind, der die App von Grund auf neu codiert, und Sie dazu gebracht wurden, die Website eines anderen zu reparieren, ohne sie auseinander zu reißen und erneut zu testen.

Knoblauchmann
quelle
Mir ist klar, dass es eine Variante von Tom Hubbards Antwort ist, die ich + 1 gemacht habe, weil es tatsächlich das ist, was ich heute selbst getan habe, bevor ich SO nach anderen Ideen gesucht habe.
Knoblauchman
2

Hier gibt es bereits viele gute Antworten. Ich möchte nur etwas aus UX-Sicht beitragen. Tastatursteuerungen in Formularen sind sehr wichtig.

Die Frage ist, wie die Übermittlung beim Tastendruck deaktiviert werden kann Enter. Nicht, wie man Enterin einer gesamten Anwendung ignoriert . Ziehen Sie daher in Betracht, den Handler an ein Formularelement anzuhängen, nicht an das Fenster.

Das Deaktivieren Enterfür das Senden von Formularen sollte weiterhin Folgendes ermöglichen:

  1. Formularübermittlung über, Enterwenn die Schaltfläche "Senden" fokussiert ist.
  2. Formularübermittlung, wenn alle Felder ausgefüllt sind.
  3. Interaktion mit nicht gesendeten Schaltflächen über Enter.

Dies ist nur eine Kesselplatte, aber es folgt allen drei Bedingungen.

$('form').on('keypress', function(e) {
  // Register keypress on buttons.
  $attr = $(e.target).attr('type);
  if ($attr === 'button' || $attr === 'submit') {
    return true;
  }

  // Ignore keypress if all fields are not populated.
  if (e.which === 13 && !fieldsArePopulated(this)) {
    return false;
  }
});

Solvitieg
quelle
1

Etwas, das ich hier nicht beantwortet gesehen habe: Wenn Sie durch die Elemente auf der Seite Enterblättern , wird durch Drücken der Schaltfläche "Senden" der Onsubmit-Handler im Formular ausgelöst, das Ereignis wird jedoch als MouseEvent aufgezeichnet. Hier ist meine kurze Lösung, um die meisten Grundlagen abzudecken:

Dies ist keine jQuery-bezogene Antwort

HTML

<form onsubmit="return false;" method=post>
  <input type="text" /><br />
  <input type="button" onclick="this.form.submit()" value="submit via mouse or keyboard" />
  <input type="button" onclick="submitMouseOnly(event)" value="submit via mouse only" />
</form>

JavaScript

window.submitMouseOnly=function(evt){
    let allow=(evt instanceof MouseEvent) && evt.x>0 && evt.y>0 && evt.screenX > 0 && evt.screenY > 0;
    if(allow)(evt.tagName=='FORM'?evt.target:evt.target.form).submit();
}

So finden Sie ein funktionierendes Beispiel: https://jsfiddle.net/nemesarial/6rhogva2/

Nemesarial
quelle
0

In meinem speziellen Fall musste ich ENTER daran hindern, das Formular zu senden, und auch das Klicken auf die Schaltfläche "Senden" simulieren. Dies liegt daran, dass auf der Schaltfläche "Senden" ein Klick-Handler vorhanden war, da wir uns in einem modalen Fenster befanden (geerbter alter Code). In jedem Fall sind hier meine Kombinationslösungen für diesen Fall.

    $('input,select').keypress(function(event) {
        // detect ENTER key
        if (event.keyCode == 13) {
            // simulate submit button click
            $("#btn-submit").click();
            // stop form from submitting via ENTER key press
            event.preventDefault ? event.preventDefault() : event.returnValue = false;
        }
    });

Dieser Anwendungsfall ist besonders nützlich für Benutzer von IE8.

Stein
quelle
0

Das funktioniert bei mir

jQuery.each($("#your_form_id").find('input'), function(){
    $(this).bind('keypress keydown keyup', function(e){
       if(e.keyCode == 13) { e.preventDefault(); }
    });
});
Pjl
quelle
0

Ich möchte einen kleinen CoffeeScript-Code hinzufügen (nicht vor Ort getestet):

$ ->
    $(window).bind 'keypress', (event) ->
        if event.keyCode == 13
            unless {'TEXTAREA', 'SELECT'}[event.originalEvent.srcElement.tagName]
                event.preventDefault()

(Ich hoffe, Ihnen gefällt der nette Trick in der Klausel "Es sei denn".)

edx
quelle
0

Verwenden von Javascript (ohne ein Eingabefeld zu überprüfen):

<script>
window.addEventListener('keydown', function(e) {
    if (e.keyIdentifier == 'U+000A' || e.keyIdentifier == 'Enter' || e.keyCode == 13) {
        e.preventDefault();
        return false;
    }
}, true);
</script>

Wenn jemand dies auf bestimmte Felder anwenden möchte, z. B. Text vom Typ Eingabe:

<script>
window.addEventListener('keydown', function(e) {
    if (e.keyIdentifier == 'U+000A' || e.keyIdentifier == 'Enter' || e.keyCode == 13) {
        if (e.target.nodeName == 'INPUT' && e.target.type == 'text') {
            e.preventDefault();
            return false;
        }
    }
}, true);
</script>

Das funktioniert in meinem Fall gut.

Waqar Alamgir
quelle
0

Gehen Sie in Ihr CSS und fügen Sie es hinzu. Dann wird die Übermittlung Ihres Formulars automatisch blockiert, solange Sie Eingaben übermittelt haben. Wenn Sie dies nicht mehr möchten, können Sie es löschen oder eingeben activateund deactivatestattdessen

 input:disabled {
        background: gainsboro;
      }
      input[value]:disabled {
        color: whitesmoke;
      }
Lars Gross
quelle
0

Sie können auch javascript:void(0)das Senden von Formularen verhindern.

<form action="javascript:void(0)" method="post">
    <label for="">Search</label>
    <input type="text">
    <button type="sybmit">Submit</button>
</form>

<form action="javascript:void(0)" method="post">
    <label for="">Search</label>
    <input type="text">
    <button type="sybmit">Submit</button>
</form>

Nisharg Shah
quelle
funktioniert nicht, wenn Sie speziell method="post"auf Ihrem Formular haben. Zum Beispiel möchte ich, dass das Formular über Schaltflächen gesendet wird, aber nicht, wenn Sie die Eingabetaste drücken, während Sie sich auf die Eingabe konzentrieren.
Souleste
Für diese Bedingung können Sie die obigen Antworten verwenden, da diese Antwort darauf basiert, das Senden von Formularen durch Eingabe und Klicken auf beide zu verhindern. obiges Beispiel method="post"in Form und seinen Werken haben, nochmal prüfen.
Nisharg Shah
-2

Dies hat bei mir in allen Browsern nach viel Frust mit anderen Lösungen funktioniert. Die äußere Funktion name_space dient nur dazu, sich von der Deklaration von Globals fernzuhalten, was ich ebenfalls empfehle.

$(function() {window.name_space = new name_space();}); //jquery doc ready
function name_space() {
    this.is_ie = (navigator.userAgent.indexOf("MSIE") !== -1);

    this.stifle = function(event) {
        event.cancelBubble;
        event.returnValue = false;
        if(this.is_ie === false) {
            event.preventDefault();
        }
        return false;
    }

    this.on_enter = function(func) {
        function catch_key(e) {
            var enter = 13;
            if(!e) {
                var e = event;
            }
            keynum = GetKeyNum(e);
            if (keynum === enter) {
                if(func !== undefined && func !== null) {
                    func();
                }
                return name_space.stifle(e);
            }
            return true; // submit
        }

        if (window.Event) {
            window.captureEvents(Event.KEYDOWN);
            window.onkeydown = catch_key;
        }
        else {
            document.onkeydown = catch_key;
        }

        if(name_space.is_ie === false) {
            document.onkeypress = catch_key;    
        }
    }
}

Beispielverwendung:

$(function() {
    name_space.on_enter(
        function () {alert('hola!');}
    );
});
crizCraig
quelle
-2

Verwenden:

// Validate your form using the jQuery onsubmit function... It'll really work...

$(document).ready(function(){
   $(#form).submit(e){
       e.preventDefault();
       if(validation())
          document.form1.submit();
   });
});

function validation()
{
   // Your form checking goes here.
}

<form id='form1' method='POST' action=''>
    // Your form data
</form>
Tapas Pal
quelle