Erkennen von „Shift Enter“ und Generieren neuer Zeilen im Textbereich mit jQuery
In Webformularen wird normalerweise durch Drücken der „Enter“-Taste in einem Textbereich gesendet das Formular. Möglicherweise möchten Sie jedoch ein anderes Verhalten implementieren, z. B. das Erstellen einer neuen Zeile, wenn „Umschalt-Eingabetaste“ gedrückt wird.
jQuery-Lösung
$("#textarea_id").on("keydown", function(evt) { if (evt.keyCode == 13 && evt.shiftKey) { // Insert a newline character if (evt.type == "keypress") { pasteIntoInput(this, "\n"); } // Prevent form submission evt.preventDefault(); } }); function pasteIntoInput(el, text) { el.focus(); if (typeof el.selectionStart == "number" && typeof el.selectionEnd == "number") { var val = el.value; var selStart = el.selectionStart; el.value = val.slice(0, selStart) + text + val.slice(el.selectionEnd); el.selectionEnd = el.selectionStart = selStart + text.length; } else if (typeof document.selection != "undefined") { var textRange = document.selection.createRange(); textRange.text = text; textRange.collapse(false); textRange.select(); } }
Einfache JavaScript-Lösung
var textarea = document.querySelector("#textarea_id"); textarea.addEventListener("keydown", function(evt) { if (evt.keyCode == 13 && evt.shiftKey) { if (evt.type == "keypress") { pasteIntoInput(this, "\n"); } evt.preventDefault(); } });
Das obige ist der detaillierte Inhalt vonWie erkennt man „Shift Enter' und erstellt neue Zeilen in einem Textbereich mit jQuery oder JavaScript?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!