Нижеследующее основано на этом ответе , но изменено для работы с выборками в любом документе (например, в документе iframe).Те же предостережения относительно наивности этого подхода, которые изложены в этом ответе, все еще применимы.
function getCaretCharacterOffsetWithin(element) {
var doc = element.ownerDocument || element.document;
var win = doc.defaultView || doc.parentWindow;
var sel, range, preCaretRange, caretOffset = 0;
if (typeof win.getSelection != "undefined") {
sel = win.getSelection();
if (sel.rangeCount) {
range = sel.getRangeAt(0);
preCaretRange = range.cloneRange();
preCaretRange.selectNodeContents(element);
preCaretRange.setEnd(range.endContainer, range.endOffset);
caretOffset = preCaretRange.toString().length;
}
} else if ( (sel = doc.selection) && sel.type != "Control") {
range = doc.selection.createRange();
preCaretRange = doc.body.createTextRange();
preCaretRange.moveToElementText(element);
preCaretRange.setEndPoint("EndToEnd", textRange);
caretOffset = preCaretTextRange.text.length;
}
return caretOffset;
}
Пример использования:
var iframe = document.getElementById("foo");
var iframeBody = (iframe.contentDocument || iframe.contentWindow.document).body;
alert( getCaretCharacterOffsetWithin(iframeBody) );