Heim >Web-Frontend >CSS-Tutorial >Wie erkennt man „Shift Enter' und erstellt neue Zeilen in einem Textbereich mit jQuery oder JavaScript?

Wie erkennt man „Shift Enter' und erstellt neue Zeilen in einem Textbereich mit jQuery oder JavaScript?

Linda Hamilton
Linda HamiltonOriginal
2024-12-06 01:51:09411Durchsuche

How to Detect

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!

Stellungnahme:
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