Sto cercando di ottenere tutti i nodi DOM che si trovano all'interno di un oggetto intervallo, qual è il modo migliore per farlo?Come ottenere i nodi che si trovano all'interno di un intervallo con 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*/;
Ho pensato a un modo per le ultime ore e arrivato fino a questo:
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;
};
Tuttavia quando il nodo finale è il genitore del nodo di partenza si ritorna tutto su la pagina. Sono sicuro che sto trascurando qualcosa di ovvio? O forse se ne sta andando nel modo sbagliato.
'var c = getSelection() getRangeAt (0) .cloneContents().; c.querySelectorAll ('*') ' – caub