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 julio de 2015.
El método MutationObserver observe() configura la funcion MutationObserver para que inicie la recepción de cambios en el DOM que coincidan con las opciones dadas.
Según la configuración, el observador verá un solo Node del árbol del DOM, o ese nodo y alguno o todos los nodos descendientes.
Para detener al MutationObserver (de modo que la funcion no sea llamada), llame al método MutationObserver.disconnect().
Sintaxis
mutationObserver.observe(target[, options])
Parámetros
target-
Un
Nodedel DOM (que puede ser unElement) perteneciente al árbol DOM, o la raiz de un subárbol de nodos, donde observar cambios. optionsOpcional-
Un objeto
MutationObserverInitopcional, que decribe qué cambios en el DOM deben ser enviados a la funcióncallbackdel observador.
Valor devuelto
undefined.
Excepciones
TypeError-
llamado en cualquiera de las siguientes circunstancias
- Las opciones han sido configuradas de tal modo que no existe nada que monitorizar (por ejemplo, si
MutationObserverInit.childList,MutationObserverInit.attributes, yMutationObserverInit.characterDatason false) - La opcion
attributesesfalse(indicando que los cambios en los atributos no son monitorizados) yattributeOldValueestruey/oattributeFilterestá presente. - Las opciones
characterDataOldValuesontrueperoMutationObserverInit.characterDataesfalse(indicando que los cambios en los caracteres no se guardan).
- Las opciones han sido configuradas de tal modo que no existe nada que monitorizar (por ejemplo, si
Notas de uso
>Reutilizar MutationObservers
Puede llamar varias veces al método observe() del mismo objeto MutationObserver para ver los cambios en diferentes partes del árbol del DOM y/o diferentes tipos de cambios. Sin embargo ha de tener en cuenta:
- Si llama a
observe()en un nodo que ya estaba siendo observado por el mísmoMutationObserver, todos los observadores serán automáticamente eliminados de todos los elementos observados antes de que el nuevo observador sea activado. - Si el mismo
MutationObserverno estaba siendo usado sobre ese nodo, entonces los observadores existentes se quedarán solos y se agregará el nuevo.
La observación sigue a los nodos cuando se desconecta
Los observadores de cambios tienen como objetivo permitirle ver un conjunto de nodos a lo largo del tiempo, incluso si la conexion entre estos nodos desaparece. Si esta observando un subárbol de nodos, y una parte del subárbol es desconectado y llevado a otra parte del DOM, continuará viendo ese mismo segmento de nodos, recibiendo las mismas llamadas a la función que antes de ser desconectado.
En otras palabras, hasta que se le haya notificado que los nodos se están separando de su subárbol monitoreado, recibirá notificaciones de los cambios en ese subárbol y sus nodos. Esto evita que pierda los cambios producidos despues de que la conexion se corte y antes de que tenga la oportunidad de especificar un nuevo monitoreo sobre los cambios en el nodo o subárbol movido.
De manera que en teoria si mantiene la pista de los objetos MutationRecord que describen los cambios, podrá "deshacer" los mismos, devolviendo el DOM a su estado inicial.
Ejemplo
>Especificaciones
| Specification |
|---|
| DOM> # ref-for-dom-mutationobserver-observe②> |
Compatibilidad con navegadores
Loading…