簡體   English   中英

在javascript中所選文本之前和之后插入文本

[英]Insert text before and after the selected text in javascript

我想在HTML文檔中任何選定的文本之前和之后放置一些指定的文本(如果可能/任何可編輯字段)。 document.getSelection()document.selection.createRange().text僅返回文本本身,而不返回位置。 無論如何,有沒有替換選定的文本? 是否在文檔中的任何位置的選定文本前后插入特定文本?

嘗試這個:

var r = document.selection.createRange();

r.text = "before" + r.text;
r.text += "after";

這是一個跨瀏覽器功能,可在所有主要瀏覽器中使用,並且與其他瀏覽器相比,IE的處理方式大為不同。

實時示例: 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);
    }
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM