MutationObserver – How to Use in Java
What Is Mutation Observer?
Mutation Observer is a built-in object that provides a way to observe and react to changes in the DOM. It is a powerful tool for building dynamic web applications that require real-time DOM manipulation and event handling. With the Mutation Observer, you can monitor changes to specific nodes, attributes, or child elements of a document and execute custom functions that respond to those changes.
In Aspose.HTML for Java library, a document observation mechanism is represented with
MutationObserver class, which is easy to configure and makes it possible to receive notifications of any changes in the document tree. This article uses Java examples to show how you can use the MutationObserver
class to observe changes in the DOM.
How To Use Mutation Observer
Mutation Observer provides the ability to observe changes in the DOM tree of a web page. The following example demonstrates the implementation of MutationObserver and how to use it to observe adding new nodes to the document.
- Create a new instance of the HTMLDocument class using HTMLDocument() constructor.
- Create a new MutationObserver object using the MutationObserver() constructor. The constructor takes a MutationCallback object as a parameter, which is used as a callback function for handling mutations.
- Use the
MutationObserverInit() constructor to create a MutationObserverInit object. You can specify what kind of changes to detect. For example,
ChildList
,Subtree
, andCharacterData
properties are set totrue
in the example. - Call the
observe() method to start observing the DOM changes. When changes occur in the
<body>
element or its child nodes that match the configured options, the callback function will be invoked to handle those mutations. - Edit the HTML document. For example, use the
createElement() method to create a new
<p>
element, and use the appendChild() method to append it to the body of the document; use the createTextNode() method to create a text node with the content “Hello, World!”, and use the appendChild() method to add it as a child node to the<p>
element. - As soon as a DOM tree change occurs, the MutationObserver callback function is fired, and it prints a message to the console indicating which node was added to the document.
1// Create an empty HTML document
2HTMLDocument document = new HTMLDocument();
3
4// Create an instance of the MutationObserver class
5MutationObserver observer = new MutationObserver(new MutationCallback() {
6 @Override
7 public void invoke(com.aspose.html.utils.collections.generic.IGenericList<MutationRecord> mutations, MutationObserver mutationObserver) {
8 for (int i = 0; i < mutations.size(); i++) {
9 MutationRecord record = mutations.get_Item(i);
10 for (Node node : record.getAddedNodes().toArray()) {
11 System.out.println("The '" + node + "' node was added to the document.");
12 }
13 }
14 }
15});
16
17// Configure options for the MutationObserver
18MutationObserverInit config = new MutationObserverInit();
19config.setChildList(true);
20config.setSubtree(true);
21config.setCharacterData(true);
22
23// Pass to observer the target node to observe with the specified configuration
24observer.observe(document.getBody(), config);
25
26// Now, we are going to modify DOM tree to check
27// Create a paragraph element and append it to the document body
28Element p = document.createElement("p");
29document.getBody().appendChild(p);
30
31// Create a text and append it to the paragraph
32Text text = document.createTextNode("Hello, World!");
33p.appendChild(text);
34
35System.out.println("Waiting for mutation. Press any key to continue...");
36System.in.read();
Recommendations
- Select specific targets and focus on specific elements or attributes when configuring
MutationObserver
to optimize performance and reduce unnecessary processing. - Use efficient callbacks – keep the logic in the callback function lightweight to prevent performance bottlenecks, especially in high mutation rate scenarios.
- Use configuration options – fine-tune the observation parameters using the
MutationObserverInit
object. Include only the necessary properties (e.g.ChildList
,Subtree
,CharacterData
) to optimize the process.
If you are observing a node for changes, your callback will not be fired until the DOM has completely finished changing. This behavior was designed to replace DOM Mutation Events and reduce the killing performance issue in the previous specification.
You can download the complete examples and data files from GitHub.