This feature is well established and works across many devices and browser versions. It’s been available across browsers since April 2018.
The before() method of the CharacterData interface inserts a set of Node objects and strings in the children list of the CharacterData's parent, just before the CharacterData node.
Strings are inserted as Text nodes; the string is being passed as argument to the Text() constructor.
before(...nodes)
None (undefined).
HierarchyRequestError DOMException
Thrown when the new nodes cannot be inserted at the specified point in the hierarchy, that is if one of the following conditions is met:
CharacterData node.DocumentFragment, a DocumentType, an Element, or a CharacterData.CharacterData node is actually a Text node, and its parent is a Document.CharacterData node is a Document and one of the nodes to insert is a DocumentFragment with more than one Element child, or that has a Text child.The before() method allows you to insert new nodes before a CharacterData node leaving the current node's data unchanged.
const h1TextNode = document.querySelector("h1").firstChild;
h1TextNode.before("h1# ");
h1TextNode.parentElement.childNodes;
// NodeList [#text "h1# ", #text "CharacterData.before()"]
h1TextNode.data;
// "CharacterData.before()"
| Specification |
|---|
| DOM> # ref-for-dom-childnode-before①> |
| Desktop | Mobile | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Chrome | Edge | Firefox | Opera | Safari | Chrome Android | Firefox for Android | Opera Android | Safari on IOS | Samsung Internet | WebView Android | WebView on iOS | |
before |
54 | 17 | 49 | 39 | 10 | 54 | 49 | 41 | 10 | 6.0 | 54 | 10 |
CharacterData.appendData()CharacterData.after()DocumentType.before()Element.before()Element.append()Node.appendChild()Element.insertAdjacentElement()
© 2005–2025 MDN contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
https://developer.mozilla.org/en-US/docs/Web/API/CharacterData/before