Heim > Web-Frontend > js-Tutorial > Hauptteil

Wie füge ich mit JavaScript Text an der Cursorposition in einen Textbereich ein?

Patricia Arquette
Freigeben: 2024-11-20 11:32:02
Original
923 Leute haben es durchsucht

How to Insert Text at the Cursor Position in a Text Area using JavaScript?

Einfügen von Text an der Cursorposition mit Javascript/jQuery

In der Webentwicklung kann das Hinzufügen von Text an der Cursorposition das Benutzererlebnis verbessern. Ein Szenario besteht darin, Benutzern zu ermöglichen, beim Klicken auf einen Link nahtlos vordefinierten Text in ein Textfeld einzufügen.

Text an der Cursorposition einfügen

Um Text an der Cursorposition einzufügen, haben wir kann die folgende JavaScript-Funktion verwenden:

function insertAtCaret(areaId, text) {
  // Get the textarea element
  var txtarea = document.getElementById(areaId);

  // Check if the element exists
  if (!txtarea) {
    return;
  }

  // Determine the browser type (Internet Explorer or others)
  var br = ((txtarea.selectionStart || txtarea.selectionStart == '0') ?
    "ff" : (document.selection ? "ie" : false));

  // Calculate the cursor position
  var strPos = 0;
  if (br == "ie") {
    txtarea.focus();
    var range = document.selection.createRange();
    range.moveStart('character', -txtarea.value.length);
    strPos = range.text.length;
  } else if (br == "ff") {
    strPos = txtarea.selectionStart;
  }

  // Create a string that consists of the text before, after, and the inserted text
  var front = (txtarea.value).substring(0, strPos);
  var back = (txtarea.value).substring(strPos, txtarea.value.length);
  txtarea.value = front + text + back;

  // Reset the cursor position after inserting the text
  strPos = strPos + text.length;
  if (br == "ie") {
    txtarea.focus();
    var ieRange = document.selection.createRange();
    ieRange.moveStart('character', -txtarea.value.length);
    ieRange.moveStart('character', strPos);
    ieRange.moveEnd('character', 0);
    ieRange.select();
  } else if (br == "ff") {
    txtarea.selectionStart = strPos;
    txtarea.selectionEnd = strPos;
    txtarea.focus();
  }
}
Nach dem Login kopieren

Beispielverwendung

Der folgende HTML- und JavaScript-Code zeigt, wie die Funktion insertAtCaret() verwendet wird:

<textarea>
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonWie füge ich mit JavaScript Text an der Cursorposition in einen Textbereich ein?. 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