is there a way to get the highlighted selectionstart and selectedlenght on a span ?
Thanks
is there a way to get the highlighted selectionstart and selectedlenght on a span ?
Thanks
Have a try on this:
var span = document.getElementById('span1');
if (document.selection) { //IE
var bm = document.selection.createRange().getBookmark();
var sel = span.createTextRange();
sel.moveToBookmark(bm);
var sleft = span.createTextRange();
sleft.collapse(true);
sleft.setEndPoint("EndToStart", sel);
span.selectionStart = sleft.text.length
span.selectionEnd = sleft.text.length + sel.text.length;
span.selectedText = sel.text;
}
else if (span.selectionStart){ //FF
span.selectedText = span.substring(span.selectionStart,span.selectionEnd);
}
alert("Selection Start==> " + span.selectionStart + "\n" +
"Selection End ==> " + span.selectionEnd + "\n" +
"Selected Text ==> " + span.selectedText + "\n" +
"TextArea Value ==> " + span.value);
I use my own optimization of the algorithms in IERange, which provides a wrapper around IE's TextRange (which is what you get from the selection in IE) to give them the same interface as DOM Ranges.
To get the selection in the document, use something like the following:
range
now has propertiesstartContainer
andstartOffset
, which are respectively a reference to a node and an offset within that node that represent the start of the selection, and corresponding propertiesendContainer
andendOffset
that represent the end of the selection.