Ответ 1
Как только вы ухватите текстовые узлы, содержащие текст, который хотите выделить, это легко. Как вы их получите, зависит от того, насколько вам это необходимо. Как и в настоящий момент, прежде чем пользователь отредактирует его, будет выполнено следующее:
var mainDiv = document.getElementById("main");
var startNode = mainDiv.firstChild.firstChild;
var endNode = mainDiv.childNodes[2].firstChild;
var range = document.createRange();
range.setStart(startNode, 6); // 6 is the offset of "world" within "Hello world"
range.setEnd(endNode, 7); // 7 is the length of "this is"
var sel = window.getSelection();
sel.removeAllRanges();
sel.addRange(range);