serialize newly added nodes and update id node map when childList changed

This commit is contained in:
Yanzhen Yu
2026-04-01 12:00:00 +08:00
parent ee4fc3ce7e
commit ad2ac811a3
3 changed files with 8 additions and 2 deletions

View File

@@ -1,4 +1,4 @@
import { INode } from 'rrweb-snapshot';
import { INode, serializeNodeWithId } from 'rrweb-snapshot';
import { mirror, throttle, on } from '../utils';
import {
mutationCallBack,
@@ -69,8 +69,8 @@ function initMutationObserver(cb: mutationCallBack): MutationObserver {
parentId: id,
id: mirror.getId(n as INode),
});
mirror.removeNodeFromMap(n as INode);
});
// TODO: init new nodes to be INode
addedNodes.forEach(n => {
adds.push({
parentId: id,
@@ -82,6 +82,7 @@ function initMutationObserver(cb: mutationCallBack): MutationObserver {
: mirror.getId(nextSibling as INode),
id: mirror.getId(n as INode),
});
serializeNodeWithId(n as INode, document, mirror.map);
});
break;
}

View File

@@ -171,6 +171,7 @@ export type Mirror = {
map: idNodeMap;
getId: (n: INode) => number;
getNode: (id: number) => INode;
removeNodeFromMap: (n: INode) => void;
};
export type throttleOptions = {

View File

@@ -17,6 +17,10 @@ export const mirror: Mirror = {
getNode(id) {
return mirror.map[id];
},
removeNodeFromMap(n) {
const id = n.__sn && n.__sn.id;
delete mirror.map[id];
},
};
// copy from underscore