diff --git a/dom.bs b/dom.bs index 0b7a6bd2..8770c427 100644 --- a/dom.bs +++ b/dom.bs @@ -2872,6 +2872,135 @@ before a child, with an optional suppress observers flag, run +
Specifications may define +moving steps for all or some nodes. The +algorithm is passed a node movedNode, and a node-or-null +oldParent as indicated in the move algorithm below. Like the +insertion steps, these steps must not modify the node tree that +insertedNode participates in, create browsing contexts, +fire events, or otherwise execute JavaScript. These steps may queue tasks +to do these things asynchronously, however. + + +
To move a node node into a node +newParent before a node child: + +
If newParent's shadow-including root is not the same as + node's shadow-including root, then throw a + "{{HierarchyRequestError!!exception}}" {{DOMException}}.
+ +This has the side effect of ensuring that a move is only performed if + newParent's connected is node's connected.
+If node is a host-including inclusive ancestor of newParent, + then throw a "{{HierarchyRequestError!!exception}}" {{DOMException}}. + +
If child is non-null and its parent is not newParent, + then throw a "{{NotFoundError!!exception}}" {{DOMException}}. + +
If node is not an {{Element}} or a {{CharacterData}} node, then + throw a "{{HierarchyRequestError!!exception}}" {{DOMException}}.
If node is a {{Text}} node and newParent is a + document, then throw a "{{HierarchyRequestError!!exception}}" {{DOMException}}. + +
If newParent is a document, node is an {{Element}} + node, and either newParent has an element + child, child is a doctype, or child is non-null and a + doctype is following child then throw a + "{{HierarchyRequestError!!exception}}" {{DOMException}}. + + +
Let oldParent be node's parent. + +
Assert: oldParent is non-null. + +
Run the live range pre-remove steps, given node. + +
For each {{NodeIterator}} object iterator whose
+ root's node document is node's
+ node document, run the NodeIterator
pre-remove steps given
+ node and iterator.
+
+
Let oldPreviousSibling be node's previous sibling. + +
Let oldNextSibling be node's next sibling. + +
If node is assigned, then run assign slottables for + node's assigned slot. + +
If oldParent's root is a shadow root, and + oldParent is a slot whose assigned nodes is the empty list, then + run signal a slot change for oldParent. + + +
If child is non-null: + +
For each live range whose start node is newParent and + start offset is greater than child's index, increase + its start offset by 1. + +
For each live range whose end node is newParent and + end offset is greater than child's index, increase + its end offset by 1. +
Let newPreviousSibling be child's previous sibling if + child is non-null, and newParent's last child otherwise. + +
If child is null, then append node to + newParent's children. + +
Otherwise, insert node into newParent's + children before child's index. + +
If newParent is a shadow host whose shadow root's
+ slot assignment is "named
" and node is a
+ slottable, then assign a slot for node.
+
+
If newParent's root is a shadow root, and + newParent is a slot whose assigned nodes is the empty list, + then run signal a slot change for newParent. + +
Run assign slottables for a tree with node's root. + +
For each shadow-including inclusive descendant inclusiveDescendant of + node, in shadow-including tree order: + +
If inclusiveDescendant is node, then run the moving steps with + inclusiveDescendant and oldParent. Otherwise, run the moving steps + with inclusiveDescendant and null. + +
Because the move algorithm is a separate primitive from + insert and remove, it does not invoke the traditional + insertion steps or removing steps for inclusiveDescendant. +
If inclusiveDescendant is custom and newParent is
+ connected, then enqueue a custom element callback reaction with
+ inclusiveDescendant, callback name "connectedMoveCallback
", and « ».
+
Queue a tree mutation record for oldParent with « », « node », + oldPreviousSibling, and oldNextSibling.
To append a node to a parent, pre-insert node into parent before null. @@ -3018,22 +3147,7 @@ optional suppress observers flag, run these steps:
Assert: parent is non-null. -
Let index be node's index. - -
For each live range whose start node is an - inclusive descendant of node, set its start to - (parent, index). - -
For each live range whose end node is an inclusive descendant - of node, set its end to (parent, index). - -
For each live range whose start node is parent and - start offset is greater than index, decrease its - start offset by 1. - -
For each live range whose end node is parent and - end offset is greater than index, decrease its - end offset by 1. +
Run the live range pre-remove steps, given node.
For each {{NodeIterator}} object iterator whose root's node document is node's @@ -3178,6 +3292,8 @@ interface mixin ParentNode { [CEReactions, Unscopable] undefined append((Node or DOMString)... nodes); [CEReactions, Unscopable] undefined replaceChildren((Node or DOMString)... nodes); + [CEReactions] undefined moveBefore(Node node, Node? child); + Element? querySelector(DOMString selectors); [NewObject] NodeList querySelectorAll(DOMString selectors); }; @@ -3225,6 +3341,16 @@ Element includes ParentNode; the node tree are violated. +
node . moveBefore(movedNode, child)
+ Moves, without first removing, movedNode into node after child + if child is non-null; otherwise after the last child of node. This + methods preserves state associated with movedNode so that it persists after the move. + +
Throws a "{{HierarchyRequestError!!exception}}" {{DOMException}} if the constraints of + the node tree are violated. + +
node . querySelector(selectors)
Returns the first element that is a descendant of node that matches selectors. @@ -3278,6 +3404,18 @@ are:
Replace all with node within this. +
The moveBefore(node, child)
+method steps are:
+
+
Let referenceChild be child. + +
If referenceChild is node, then set referenceChild to + node's next sibling. + +
The querySelector(selectors)
method
steps are to return the first result of running scope-match a selectors string
selectors against this, if the result is not an empty list; otherwise null.
@@ -8112,8 +8250,8 @@ interface Range : AbstractRange {
live ranges.
Algorithms that modify a tree (in particular the insert, -remove, replace data, and split algorithms) modify -live ranges associated with that tree. +remove, move, replace data, and split +algorithms) modify live ranges associated with that tree.
The root of a live range is the root of its start node. @@ -8179,6 +8317,32 @@ but not its end node, or vice versa. +
The live range pre-remove steps given a node node, are as +follows: + +
Let parent be node's parent. + +
Assert: parent is not null. + +
Let index be node's index. + +
For each live range whose start node is an + inclusive descendant of node, set its start to + (parent, index). + +
For each live range whose end node is an inclusive descendant + of node, set its end to (parent, index). + +
For each live range whose start node is parent and + start offset is greater than index, decrease its + start offset by 1. + +
For each live range whose end node is parent and + end offset is greater than index, decrease its + end offset by 1. +