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: + +

    + +
  1. +

    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.

    +
  2. + +
  3. If node is a host-including inclusive ancestor of newParent, + then throw a "{{HierarchyRequestError!!exception}}" {{DOMException}}. + +

  4. If child is non-null and its parent is not newParent, + then throw a "{{NotFoundError!!exception}}" {{DOMException}}. + +

  5. If node is not an {{Element}} or a {{CharacterData}} node, then + throw a "{{HierarchyRequestError!!exception}}" {{DOMException}}.

  6. + +
  7. If node is a {{Text}} node and newParent is a + document, then throw a "{{HierarchyRequestError!!exception}}" {{DOMException}}. + +

  8. 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}}. + + +

  9. Let oldParent be node's parent. + +

  10. Assert: oldParent is non-null. + +

  11. Run the live range pre-remove steps, given node. + +

  12. 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. + +

  13. Let oldPreviousSibling be node's previous sibling. + +

  14. Let oldNextSibling be node's next sibling. + +

  15. Remove node from oldParent's children. + +

  16. If node is assigned, then run assign slottables for + node's assigned slot. + +

  17. 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. + + +

  18. +

    If child is non-null: + +

      +
    1. For each live range whose start node is newParent and + start offset is greater than child's index, increase + its start offset by 1. + +

    2. For each live range whose end node is newParent and + end offset is greater than child's index, increase + its end offset by 1. +

    + +
  19. Let newPreviousSibling be child's previous sibling if + child is non-null, and newParent's last child otherwise. + +

  20. If child is null, then append node to + newParent's children. + +

  21. Otherwise, insert node into newParent's + children before child's index. + +

  22. 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. + +

  23. 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. + +

  24. Run assign slottables for a tree with node's root. + +

  25. +

    For each shadow-including inclusive descendant inclusiveDescendant of + node, in shadow-including tree order: + +

      +
    1. +

      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. +

    2. + +
    3. If inclusiveDescendant is custom and newParent is + connected, then enqueue a custom element callback reaction with + inclusiveDescendant, callback name "connectedMoveCallback", and « ». +

    +
  26. + +
  27. Queue a tree mutation record for oldParent with « », « node », + oldPreviousSibling, and oldNextSibling.

  28. + +
  29. Queue a tree mutation record for newParent with « node », « », + newPreviousSibling, and child.

  30. +
+ +

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: + +

      +
    1. Let referenceChild be child. + +

    2. If referenceChild is node, then set referenceChild to + node's next sibling. + +

    3. Move node into this before referenceChild. +

    +

    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: + +

      +
    1. Let parent be node's parent. + +

    2. Assert: parent is not null. + +

    3. Let index be node's index. + +

    4. For each live range whose start node is an + inclusive descendant of node, set its start to + (parent, index). + +

    5. For each live range whose end node is an inclusive descendant + of node, set its end to (parent, index). + +

    6. For each live range whose start node is parent and + start offset is greater than index, decrease its + start offset by 1. + +

    7. For each live range whose end node is parent and + end offset is greater than index, decrease its + end offset by 1. +

    +