Skip to content

Commit

Permalink
fix: ensure child node is a child of parent before removing
Browse files Browse the repository at this point in the history
Fixes glimmerjsGH-1401

If `current` isn't a child of `parent` calling `parent.removeChild(current)` will result in the error: `Failed to execute 'removeChild' on 'Node': The node to be removed is not a child of this node`. This commonly occurs when the DOM is externally modified by a browser, such as when translating a page. The `nextSibling` may not be a child node of `parent`.

`current.parentNode?.removeChild(current)` ensures we are only removing a child node of a parent node.
  • Loading branch information
shama authored Aug 24, 2023
1 parent 68d371b commit 54cbd16
Showing 1 changed file with 1 addition and 2 deletions.
3 changes: 1 addition & 2 deletions packages/@glimmer/runtime/lib/bounds.ts
Original file line number Diff line number Diff line change
Expand Up @@ -65,7 +65,6 @@ export function move(bounds: Bounds, reference: Nullable<SimpleNode>): Nullable<
}

export function clear(bounds: Bounds): Nullable<SimpleNode> {
let parent = bounds.parentElement();
let first = bounds.firstNode();
let last = bounds.lastNode();

Expand All @@ -75,7 +74,7 @@ export function clear(bounds: Bounds): Nullable<SimpleNode> {
while (true) {
let next = current.nextSibling;

parent.removeChild(current);
current.parentNode?.removeChild(current);

if (current === last) {
return next;
Expand Down

0 comments on commit 54cbd16

Please sign in to comment.