Heim > Web-Frontend > js-Tutorial > Wie kann man die Caret-Position in einem ContentEditable-Element programmgesteuert festlegen?

Wie kann man die Caret-Position in einem ContentEditable-Element programmgesteuert festlegen?

Barbara Streisand
Freigeben: 2024-12-05 19:20:11
Original
912 Leute haben es durchsucht

How to Programmatically Set the Caret Position in a ContentEditable Element?

Festlegen der Caret-Position in einem inhaltsbearbeitbaren Element

Das Festlegen der Caret-Position in einem inhaltsbearbeitbaren Div kann mithilfe der Range- und Selection-Objekte erreicht werden. So setzen Sie die Einfügemarke auf eine bestimmte Position innerhalb des Elements:

Code:

function setCaret() {
    var el = document.getElementById("editable")
    var range = document.createRange()
    var sel = window.getSelection()
    
    range.setStart(el.childNodes[2], 5)
    range.collapse(true)
    
    sel.removeAllRanges()
    sel.addRange(range)
}
Nach dem Login kopieren

Erklärung:

  • el stellt das inhaltsbearbeitbare Element dar.
  • range ist das Range-Objekt, das zur Angabe der Cursorposition verwendet wird.
  • sel ist das Selection-Objekt, das zur Manipulation verwendet wird die Auswahl.
  • setStart() setzt den Anfang des Bereichs auf den angegebenen Knoten und Offset (el.childNodes[2] bzw. 5).
  • collapse() reduziert den Bereich auf ein einzelner Punkt an der Startposition.
  • removeAllRanges() entfernt alle vorhandenen Auswahlen.
  • addRange() fügt den erstellten Bereich hinzu die Auswahl.

Beispiel:

Bedenken Sie den folgenden HTML-Code:

<div>
Nach dem Login kopieren

Wenn Sie auf die Schaltfläche „Fokus“ klicken, wird die JavaScript-Funktion setCaret() angezeigt aufgerufen und das Caretzeichen am fünften Zeichen der zweiten Textzeile platziert.

Das obige ist der detaillierte Inhalt vonWie kann man die Caret-Position in einem ContentEditable-Element programmgesteuert festlegen?. 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