MutationObserver.observe()
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.
MutationObserver
의 observe()
메서드는 지정한 옵션을 만족하는 DOM 변경 알림을 수신한 경우 MutationObserver
의 콜백을 호출하도록 설정합니다.
설정에 따라서 MutationObserver
는 DOM 트리의 단일 Node
를 주시하거나, 노드와 그 아래 노드를 모두 주시할 수 있습니다.
MutationObserver
의 콜백이 더 이상 호출되지 않도록 하려면 MutationObserver.disconnect()
를 사용하세요.
구문
observe(target, options)
매개변수
target
options
-
주시하고자 하는 DOM 변경을 나타내는 객체입니다. 이 옵션을 만족하는 DOM 변경들만
MutationObserver
의 콜백으로 전달됩니다. 적어도childList
,attributes
,characterData
중 하나는true
여야 하며 세 속성 모두false
면TypeError
가 발생합니다.사용 가능한 옵션은 다음과 같습니다.
subtree
Optional-
true
로 지정하면target
이 루트인 하위 트리 전체를 주시합니다. 다른 옵션들도target
노드 하나가 아니라 이 하위 트리에 속한 모든 노드에 대해 적용됩니다. 기본 값은false
입니다. childList
Optional-
true
로 지정하면 대상 노드에 자식이 추가되거나 기존 자식이 제거되는 것을 감지합니다.subtree
가true
면 자손들의 자식 변경도 감지합니다. 기본 값은false
입니다. attributes
Optional-
true
로 지정하면 주시 중인 노드 또는 노드들의 특성 변경을 감지합니다. 기본 값은attributeFilter
또는attributeOldValue
가 지정된 경우true
, 아니면false
입니다. attributeFilter
Optional-
변경을 감지할 특성 이름의 배열입니다. 이 속성을 지정하지 않으면 모든 특성의 변경이 알림을 생성합니다.
attributeOldValue
Optional-
true
로 지정하면 노드의 특성 변경을 감지했을 때 해당 특성이 바뀌기 전 값을 기록합니다. 기본 값은false
입니다. characterData
Optional-
true
로 지정하면 대상 노드 내의 텍스트가 바뀌는 것을 감지합니다.subtree
가true
면 자손들의 텍스트 변경도 감지합니다. 기본 값은characterDataOldValue
가 지정된 경우true
, 아니면false
입니다. characterDataOldValue
Optional-
true
로 지정하면 노드의 텍스트 변경을 감지했을 때 바뀌기 전의 텍스트를 기록합니다. 기본 값은false
입니다.
반환 값
없음 (undefined
).
예외
TypeError
-
다음 상황에서 발생합니다.
-
지정한
options
로는 감지할 수 있는 변경이 없을 때 (childList
,attributes
,characterData
가 모두false
일 때) options
의attributes
가false
(특성 변경을 감지하지 않음)인데attributeOldValue
가true
거나attributeFilter
를 지정한 경우options
의characterData
가false
(텍스트 변경을 감지하지 않음)인데characterDataOldValue
가true
인 경우
-
지정한
사용 일람
MutationObserver 재활용
MutationObserver
인스턴스 하나의 observe()
를 여러 번 호출하면 DOM 트리 곳곳의 서로 다른 변경 유형을 하나의 감지기만으로 감지할 수 있습니다. 하지만 주의해야 할 점이 있습니다.
- 어떤
MutationObserver
인스턴스가 주시 중인 노드를 같은 인스턴스로 다시 주시할 경우, 이 노드에 대한 해당 인스턴스의 기존 주시는 자동으로 해제되고 새로 시작합니다. MutationObserver
인스턴스가 그 노드를 주시하고 있지 않았다면 다른 주시들은 영향을 받지 않습니다.
트리 분리 후에도 주시는 지속됨
MutationObserver
는 노드들의 연결이 끊어져도 주시가 끊기지 않도록 설계됐습니다. 그래서 주시 중인 하위 트리의 일부를 분리해 DOM의 다른 곳으로 옮기는 동시에 그 노드들의 특성을 변경하는 경우에도 특성 변경 알림까지 수신할 수 있습니다.
다시 말해, 주시 중인 하위 트리에서 노드가 분리된다는 알림이 콜백까지 전달되기 전까지는 분리된 하위 트리와 해당 노드의 변경 사항에 대한 알림을 계속 받습니다.
이와 같은 주시 동작으로 인해, 각각의 변경을 나타내는 MutationRecord
객체들을 보관해둔다면 이론적으로는 트리의 분리를 "실행 취소" 하여 DOM 상태를 되감는 게 가능합니다.
예제
기본 예제
이 예제에서는 MutationObserver
인스턴스를 생성한 후 대상 노드와 옵션 객체를 사용해 observe()
메서드를 호출하는 방법을 보입니다.
// 주시할 요소 식별
const elementToObserve = document.querySelector("#targetElementId");
// 콜백 함수를 지정한 새로운 MutationObserver 인스턴스 생성
// observer 변수에 할당
const observer = new MutationObserver(() => {
console.log("callback that runs when observer is triggered");
});
//
// 위 MutationObserver 인스턴스의 observe() 메서드를 호출
// 주시할 요소와 옵션 객체 전달
observer.observe(elementToObserve, { subtree: true, childList: true });
attributeFilter
사용하기
이 예제는 채팅방을 가정하고, 사용자들의 이름을 포함한 하위 트리를 주시하여 status
와 username
특성의 변경를 감지합니다. 그 후에는 사용자가 닉네임을 변경한 경우를 반영하거나, 자리비움 상태를 강조하는 등의 기능을 추가할 수 있을 것입니다.
function callback(mutationList) {
mutationList.forEach((mutation) => {
switch (mutation.type) {
case "attributes":
switch (mutation.attributeName) {
case "status":
userStatusChanged(mutation.target.username, mutation.target.status);
break;
case "username":
usernameChanged(mutation.oldValue, mutation.target.username);
break;
}
break;
}
});
}
const userListElement = document.querySelector("#userlist");
const observer = new MutationObserver(callback);
observer.observe(userListElement, {
attributeFilter: ["status", "username"],
attributeOldValue: true,
subtree: true,
});
명세서
Specification |
---|
DOM Standard # ref-for-dom-mutationobserver-observe② |
브라우저 호환성
BCD tables only load in the browser