MutationObserver Records Wrong DOM Element (editable Div)
Lorem ipsum...
#contentEditableDiv {
border: 1px solid black;
min-height: 200px;
width: 200px;
}
#contentEditableDiv p{
border: 1px solid red;
margin-left: 5px;
margin-right: 5px;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.1.1/jquery.min.js"></script>
<div id="contentEditableDiv" contenteditable="true" >
<p id="content0">Lorem ipsum...</p>
<p id="content1">Lorem ipsum...</p>
</div>
But I will not accept my answer cause I still do not know WHY the mutationObserver
returns the wrong element.
Solution 2:
This has nothing to do with MutationObserver
, it's not returning the wrong element. When you press enter inside any element within a contenteditable
container it gets duplicated, which is why the element reported by MutationObserver
has the same id. If you try to locate the element through DevTools, it will show you the most recently added one - because it has the same id.
#uniqueOrIsIt {
border: 1px solid gold;
}
.paragraph {
border: 1px solid blue;
}
<div contenteditable="true">
<p id="uniqueOrIsIt">text</p>
<p class="paragraph">text</p>
<p style="border: 1px solid green;color:green">text</p>
</div>
All three of the p
elements will get duplicated with the exact same attributes.
The solution depends on what you're trying to accomplish - do you want each inserted p
element to have a new unique id? In that case you can, for each mutation, check if any of the addedNodes
are p
elements and if they are, assign them a unique id. Keep a simple let counter = 1
and set the ids as addedNode.setAttribute('id', ('content' + counter++))
Post a Comment for "MutationObserver Records Wrong DOM Element (editable Div)"