• 作为前端你还不懂MutationObserver?那Out了


    🐱 个人主页不叫猫先生
    🙋‍♂️ 作者简介:前端领域新星创作者、阿里云专家博主,专注于前端各领域技术,共同学习共同进步,一起加油呀!
    💫系列专栏:vue3从入门到精通TypeScript从入门到实践
    📢 资料领取:前端进阶资料以及文中源码可以找我免费领取
    🔥 前端学习交流:博主建立了一个前端交流群,汇集了各路大神,互相交流学习,期待你的加入!(文末有我wx或者直接私信)

    🥙前言

    为什么突然写MutationObserver呢?最近在写页面水印的时候用到了MutationObserver方法,两者之间有什么联系呢?不用MutationObserver情况下,使用网站的人员可以随意修改DOM就可以把系统作者的版权标识(水印)去掉,然后使用无水印的网站,这显然是违背了系统作者的意愿,那么怎么防止这一操作呢?当然是MutationObserver,它能够监听DOM的变化,根据DOM的变化然后做出相应操作,比如删除水印后,使用MutationObserver监听到了水印的DOM被删除,就会立即生成一个水印,这样就杜绝了上面的情况。

    🥪一、MutationObserver

    MutationObserver构造函数用来监听DOM的变化,比如节点增加、删除,属性的改变,文本的变动都能监听到。它具有以下特点:

    • 等所有dom操作结束后才触发,可以看成异步
    • 会把dom的变化记录放到数组中进行处理
    • 可以监听所有类型的dom变化,也能指定类型监听

    用MutationObserver创建一个createObserve实例, 它会在指定的 DOM 发生变化时被调用。其中MutationObserver构造函数中有两个参数。

    • mutationRecoard:存放所有dom变化的数组
    • observe:观察者实例
    const createObserve = new MutationObserver((mutationRecoard,observe)=>{
    
    })
    
    • 1
    • 2
    • 3

    1. MutationRecoard监听记录详情

    dom每次变化都会记录在MutationRecoard中,所以它是一个数组类型,MutationRecoard记录了每次DOM变化时的详细信息,具体如下所示:

    属性含义
    type观察的变动类型(attribute、characterData或者childList)
    target发生变动的DOM节点
    addedNodes新增的DOM节点
    removedNodes删除的DOM节点
    previousSibling前一个同级节点,如果没有则返回null
    nextSibling下一个同级节点,如果没有则返回null
    attributeName发生变动的属性。如果设置了attributeFilter,则只返回预先指定的属性
    oldValue变动前的值。这个属性只对attribute和characterData变动有效,如果发生childList变动,则返回null

    具体如下图所示:

    在这里插入图片描述

    🌮二、MutationObserver实例对象方法

    1. observe(node,config)

    配置 MutationObserver 在 DOM 更改匹配给定选项时,通过其回调函数开始接收通知。有两个参数:

    • node:观察元素的所有节点
    • config:配置项,可以观测指定配置项的变化

    配置项的详细属性如下:

    属性含义
    childList子节点的变动(指新增,删除或者更改)
    attributes属性的变动
    characterData节点内容或节点文本的变动
    subtree布尔值,表示是否将该观察器应用于该节点的所有后代节点
    attributeOldValue布尔值,表示观察attributes变动时,是否需要记录变动前的属性值
    characterDataOldValue布尔值,表示观察characterData变动时,是否需要记录变动前的值
    attributeFilter数组,表示需要观察的特定属性(比如[‘class’,‘src’])

    2. disconnect()

    阻止 MutationObserver 实例继续接收的通知,直到再次调用其 observe() 方法,该观察者对象包含的回调函数都不会再被调用。

    3. takeRecords()

    从 MutationObserver 的通知队列中删除所有待处理的记录,并将它们返回到 MutationRecord 对象的新 Array 中。

    🍔三、案列

    • 创建一个观察器并传入回调
    • 为观察器配置观察节点
    • 指定观察特定配置的dom变化
    • 执行观察器回调
    • 获取到DOM变化记录
    	<div class="content">
    		<ui>
    			<li class="0">0000000li>
    			<li class="1">1111111li>
    			<li class="2">222222li>
    			<li class="3">33333li>
    			<li class="4">4444li>
    			<li class="5">55555li>
    			<li class="6">6666li>
    			<li class="7">77777li>
    			<li class="8">888888li>
    			<li class="9">99999li>
    		ui>
    	div>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    // 观察器的配置(需要观察什么变动)
    const config = { attributes: true, childList: true, subtree: true,characterData:true,characterDataOldValue:true,attributDataOldValue:true};
    
    // 当观察到变动时执行的回调函数
    const callback = function(mutationRecoard, observer) {
        // Use traditional 'for loops' for IE 11
        for(let mutation of mutationRecoard) {
            if (mutation.type === 'childList') {
                console.log('A child node has been added or removed.');
            }
            else if (mutation.type === 'attributes') {
                console.log('The ' + mutation.attributeName + ' attribute was modified.');
            }
        }
    };
    
    // 创建一个观察器实例并传入回调函数
    const observer = new MutationObserver(callback);
    
    // 以上述配置开始观察目标节点
    observer.observe(document.getElementsByClassName('content')[0], config);
    
    // 之后,可停止观察
    observer.disconnect();
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
  • 相关阅读:
    深度学习与CV教程(12) | 目标检测 (两阶段,R-CNN系列)
    linux docker常用命令记录
    使用python脚本玩转古早TCAD软件(待更新)
    考研以后还是要工作,那考研的意义在哪里呢?
    利用证书给pdf文件添加数字签名
    03-QNX高可用框架HAM研究(转)
    MySQL系列3:缓冲池Buffer Pool的设计思想
    好用的云笔记具备哪些特点,这3款云笔记亲测好用
    【luogu P8354】多边形(容斥)(NTT优化DP)
    Vue-2.2组件通信
  • 原文地址:https://blog.csdn.net/qq_38951259/article/details/128089591