在javascript中选定的文本之前和之后插入文本
问题描述:
我想在HTML文档中的任何选定文本之前和之后放置一些指定的文本(如果可能/任何可编辑的字段)。 document.getSelection()
或document.selection.createRange().text
只返回文本本身而不是位置。 无论如何要替换选定的文本?无论如何在文档中的任意位置选择文本之前和之后插入特定文本?在javascript中选定的文本之前和之后插入文本
答
这里是一个跨浏览器的功能,要做到这一点,它适用于所有主要的浏览器,并迎合千差万别的方式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);
}
}
答
试试这个:
var r = document.selection.createRange();
r.text = "before" + r.text;
r.text += "after";
+0
它正在工作..谢谢! – SMUsamaShah 2011-01-22 20:58:54
你可以得到的字符串,添加要开始和结束的东西,然后重新插入原来的位置? – JakeParis 2011-01-22 20:47:38
如何'重新插入'到'原始位置' – SMUsamaShah 2011-01-22 20:48:58