Heim Web-Frontend js-Tutorial Wie füge ich mithilfe von JavaScript HTML an der Cursorposition in ein inhaltsbearbeitbares Div ein?

Wie füge ich mithilfe von JavaScript HTML an der Cursorposition in ein inhaltsbearbeitbares Div ein?

Nov 12, 2024 pm 10:45 PM

How do I insert HTML at the cursor position in a contenteditable div using JavaScript?

HTML am Cursor in ein inhaltsbearbeitbares Div einfügen

Bei der Arbeit mit einem inhaltsbearbeitbaren Div ist es oft notwendig, HTML am Cursor einzufügen Position. Dies kann mithilfe von JavaScript erfolgen, um das Tastendruckereignis zu erfassen und das Standardverhalten der Eingabetaste zu verhindern.

Um HTML einzufügen, können wir die Methode insertNode() des Range-Objekts verwenden. Mit dieser Methode können wir einen Knoten an einer bestimmten Stelle in das DOM einfügen. In den meisten Browsern, außer IE < 9 können wir diese Methode direkt verwenden.

Hier ist eine Funktion, die zeigt, wie man HTML an der Cursorposition in allen gängigen Browsern einfügt, unabhängig davon, ob der Inhalt ausgewählt ist oder nicht:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

function pasteHtmlAtCaret(html, selectPastedContent) {

    var sel, range;

    if (window.getSelection) {

        // IE9 and non-IE

        sel = window.getSelection();

        if (sel.getRangeAt &amp;amp;&amp;amp; sel.rangeCount) {

            range = sel.getRangeAt(0);

            range.deleteContents();

 

            // Create a document fragment to hold the HTML

            var el = document.createElement(&quot;div&quot;);

            el.innerHTML = html;

            var frag = document.createDocumentFragment(), node, lastNode;

            while ( (node = el.firstChild) ) {

                lastNode = frag.appendChild(node);

            }

 

            // Insert the HTML into the document

            range.insertNode(frag);

 

            // Preserve the selection

            if (lastNode) {

                range = range.cloneRange();

                range.setStartAfter(lastNode);

                if (selectPastedContent) {

                    range.setStartBefore(firstNode);

                } else {

                    range.collapse(true);

                }

                sel.removeAllRanges();

                sel.addRange(range);

            }

        }

    } else if ( (sel = document.selection) &amp;amp;&amp;amp; sel.type != &quot;Control&quot;) {

        // IE &lt; 9

        var originalRange = sel.createRange();

        originalRange.collapse(true);

        sel.createRange().pasteHTML(html);

        if (selectPastedContent) {

            range = sel.createRange();

            range.setEndPoint(&quot;StartToStart&quot;, originalRange);

            range.select();

        }

    }

}

Nach dem Login kopieren

In IE < 9 können wir die Methode pasteHTML() des Range-Objekts verwenden, um HTML einzufügen.

Diese Methode ist flexibler, da sie es uns ermöglicht anzugeben, ob wir den eingefügten Inhalt auswählen möchten oder nicht.

Um diese Funktion aufzurufen, übergeben Sie einfach den HTML-Code, den Sie einfügen möchten, und einen booleschen Wert, um anzugeben, ob der eingefügte Inhalt ausgewählt werden soll oder nicht.

Zum Beispiel:

1

2

3

4

pasteHtmlAtCaret('<p>New HTML</p>', true);<p></p><p>Das obige ist der detaillierte Inhalt vonWie füge ich mithilfe von JavaScript HTML an der Cursorposition in ein inhaltsbearbeitbares Div ein?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!</p>

 

 

                        

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

Heiße Artikel -Tags

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Ersetzen Sie Stringzeichen in JavaScript Ersetzen Sie Stringzeichen in JavaScript Mar 11, 2025 am 12:07 AM

Ersetzen Sie Stringzeichen in JavaScript

Benutzerdefinierte Google -Search -API -Setup -Tutorial Benutzerdefinierte Google -Search -API -Setup -Tutorial Mar 04, 2025 am 01:06 AM

Benutzerdefinierte Google -Search -API -Setup -Tutorial

Beispielfarben JSON -Datei Beispielfarben JSON -Datei Mar 03, 2025 am 12:35 AM

Beispielfarben JSON -Datei

8 atemberaubende JQuery -Seiten -Layout -Plugins 8 atemberaubende JQuery -Seiten -Layout -Plugins Mar 06, 2025 am 12:48 AM

8 atemberaubende JQuery -Seiten -Layout -Plugins

10 JQuery Syntax Highlighters 10 JQuery Syntax Highlighters Mar 02, 2025 am 12:32 AM

10 JQuery Syntax Highlighters

Erstellen Sie Ihre eigenen AJAX -Webanwendungen Erstellen Sie Ihre eigenen AJAX -Webanwendungen Mar 09, 2025 am 12:11 AM

Erstellen Sie Ihre eigenen AJAX -Webanwendungen

Was ist ' this ' in JavaScript? Was ist ' this ' in JavaScript? Mar 04, 2025 am 01:15 AM

Was ist ' this ' in JavaScript?

10 JavaScript & JQuery MVC -Tutorials 10 JavaScript & JQuery MVC -Tutorials Mar 02, 2025 am 01:16 AM

10 JavaScript & JQuery MVC -Tutorials

See all articles