I have contentEditable element (can be p, div, ...) and I would like to get caret (cursor) position in it. I can normally achieve it with this piece of code:
var position = window.getSelection().getRangeAt(0).startOffset;
This works fine while the element contains just text. But when the element contains some HTML formatting, the returned position is relative to caret position within included HTML element.
Let's assume contents of contentEditable element is this:
AB<b>CD</b>EF
If caret is inside <b></b>
, let's say between C and D, the returned position with above code is 1 instead of 3 (counted from the begining of the contentEditable element's content)
Can anybody come up with solution to this ?
UPDATE
I've written a simpler version of this that also works in IE < 9:
https://stackoverflow.com/a/4812022/96100
Old Answer
This is actually a more useful result than a character offset within the text of the whole document: the
startOffset
property of a DOM Range (which is whatwindow.getSelection().getRangeAt()
returns) is an offset relative to itsstartContainer
property (which isn't necessarily always a text node, by the way). However, if you really want a character offset, here's a function that will do it.Here's a live example: http://jsfiddle.net/timdown/2YcaX/
Here's the function:
If you want to insert element then you could try to do something like this:
This is a very old post, but still one of the first results searching on Google, so maybe still useful. This works for me to get right position considering html tags and newlines as well (tested on Firefox):
It uses the cloneContents functionality in order to get the actual html and appends the documentfragment to a temporary div in order to get the html length.