Insert text before and after the selected text in javascript

后端 未结 2 696
南笙
南笙 2020-12-20 05:47

I want to put some specified text (where possible/any editable field) before and after any selected text in an HTML document. document.getSelection() or d

相关标签:
2条回答
  • 2020-12-20 06:22

    Here's a cross-browser function to do this, which works in all major browsers and caters for the vastly different way IE does this compared to other browsers.

    Live example: http://jsfiddle.net/timdown/UWExN/64/

    function insertHtmlAtSelectionEnd(html, isBefore) {
        var sel, range, node;
        if (window.getSelection) {
            sel = window.getSelection();
            if (sel.getRangeAt && sel.rangeCount) {
                range = window.getSelection().getRangeAt(0);
                range.collapse(isBefore);
    
                // Range.createContextualFragment() would be useful here but was
                // until recently non-standard and not supported in all browsers
                // (IE9, for one)
                var el = document.createElement("div");
                el.innerHTML = html;
                var frag = document.createDocumentFragment(), node, lastNode;
                while ( (node = el.firstChild) ) {
                    lastNode = frag.appendChild(node);
                }
                range.insertNode(frag);
            }
        } else if (document.selection && document.selection.createRange) {
            range = document.selection.createRange();
            range.collapse(isBefore);
            range.pasteHTML(html);
        }
    }
    
    0 讨论(0)
  • 2020-12-20 06:22

    Try this:

    var r = document.selection.createRange();
    
    r.text = "before" + r.text;
    r.text += "after";
    
    0 讨论(0)
提交回复
热议问题