Próbuję uzyskać wszystkie węzły DOM, które są w zasięgu obiektu, jaki jest najlepszy sposób to zrobić?Jak uzyskać węzły leżące wewnątrz zakresu z javascript?
var selection = window.getSelection(); //what the user has selected
var range = selection.getRangeAt(0); //the first range of the selection
var startNode = range.startContainer;
var endNode = range.endContainer;
var allNodes = /*insert magic*/;
Byłem myślał o sposób, w ciągu ostatnich kilku godzin i podszedł z tym:
var getNextNode = function(node, skipChildren){
//if there are child nodes and we didn't come from a child node
if (node.firstChild && !skipChildren) {
return node.firstChild;
}
if (!node.parentNode){
return null;
}
return node.nextSibling
|| getNextNode(node.parentNode, true);
};
var getNodesInRange = function(range){
var startNode = range.startContainer.childNodes[range.startOffset]
|| range.startContainer;//it's a text node
var endNode = range.endContainer.childNodes[range.endOffset]
|| range.endContainer;
if (startNode == endNode && startNode.childNodes.length === 0) {
return [startNode];
};
var nodes = [];
do {
nodes.push(startNode);
}
while ((startNode = getNextNode(startNode))
&& (startNode != endNode));
return nodes;
};
Jednak gdy węzeł końcowy jest rodzicem węzła początkowego zwraca na wszystko Strona. Jestem pewien, że przeoczyłem coś oczywistego? A może dzieje się to w zupełnie niewłaściwy sposób.
'var c = getSelection() getRangeAt (0) .cloneContents (.); c.querySelectorAll ('*') ' – caub