Skip to content

Commit a48efdf

Browse files
[Term Entry] JavaScript DOM Manipulation: .replaceChildren() (#6332)
* Add replaceChildren entry * minor fixes ---------
1 parent f3a72ba commit a48efdf

File tree

2 files changed

+69
-0
lines changed

2 files changed

+69
-0
lines changed
Lines changed: 69 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,69 @@
1+
---
2+
Title: '.replaceChildren()'
3+
Description: 'Replaces all child nodes of an element with new nodes or clears them if no arguments are provided.'
4+
Subjects:
5+
- 'Web Development'
6+
- 'Web Design'
7+
Tags:
8+
- 'Arguments'
9+
- 'DOM'
10+
- 'ES6'
11+
- 'Functions'
12+
CatalogContent:
13+
- 'introduction-to-javascript'
14+
- 'paths/front-end-engineer-career-path'
15+
---
16+
17+
The **`.replaceChildren()`** method in JavaScript is a modern DOM manipulation method that replaces all child nodes of an element with new specified nodes or clears them if no arguments are provided.
18+
19+
Unlike older methods such as `.innerHTML` or [`.removeChild()`](https://www.codecademy.com/resources/docs/javascript/dom-manipulation/removeChild), `.replaceChildren()` provides a cleaner, more efficient, and safer way to update the contents of an element without unnecessary parsing or manipulation overhead.
20+
21+
This method is particularly useful when dynamically updating UI elements, such as replacing a list of items, updating content sections, or efficiently clearing an element's children without affecting event listeners on the parent.
22+
23+
## Key Characteristics
24+
25+
- More efficient than manually removing and appending children.
26+
- Accepts multiple nodes or strings as arguments.
27+
- Works similarly to `.innerHTML = ""` for clearing, but safer as it avoids HTML parsing.
28+
29+
## Syntax
30+
31+
```pseudo
32+
element.replaceChildren(...nodes);
33+
```
34+
35+
- `nodes` (optional): One or more nodes or strings to insert as new children. If no arguments are provided, all child nodes are removed.
36+
37+
## Example
38+
39+
The following example demonstrates the usage of the `.replaceChildren()` method:
40+
41+
```html
42+
<!DOCTYPE html>
43+
<html lang="en">
44+
<head>
45+
<title>replaceChildren Example</title>
46+
</head>
47+
<body>
48+
<div id="container">
49+
<p>Old content</p>
50+
</div>
51+
<button onclick="updateContent()">Replace Content</button>
52+
53+
<script>
54+
function updateContent() {
55+
let container = document.getElementById('container');
56+
let newParagraph = document.createElement('p');
57+
newParagraph.textContent = 'New content added!';
58+
container.replaceChildren(newParagraph);
59+
}
60+
</script>
61+
</body>
62+
</html>
63+
```
64+
65+
In this example, the `.replaceChildren()` removes the existing `<p>` inside `#container` and replaces it with a new one. If called without arguments, it clears all children.
66+
67+
The output will be:
68+
69+
![A div showing "Old content" updates to "New content added!" when the button is clicked.](https://raw.githubusercontent.com/Codecademy/docs/main/media/replace-children-example.gif)

media/replace-children-example.gif

84.3 KB
Loading

0 commit comments

Comments
 (0)