作为前端你还不懂MutationObserver?那Out了
创始人
2024-03-12 02:12:40
0

🐱个人主页:不叫猫先生
🙋‍♂️作者简介:前端领域新星创作者、华为云享专家、阿里云专家博主,专注于前端各领域技术,共同学习共同进步,一起加油呀!
💫系列专栏:vue3从入门到精通
📝个人签名:不破不立

🍬目录

  • 🥙前言
  • 🥪一、MutationObserver
    • 1. MutationRecoard监听记录详情
  • 🌮二、MutationObserver实例对象方法
    • 1. observe(node,config)
    • 2. disconnect()
    • 3. takeRecords()
  • 🍔三、案列

🥙前言

为什么突然写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. 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变化记录
	
  • 0000000
  • 1111111
  • 222222
  • 33333
  • 4444
  • 55555
  • 6666
  • 77777
  • 888888
  • 99999
  • // 观察器的配置(需要观察什么变动)
    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 11for(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();

    相关内容

    热门资讯

    国家矿山安全监察局公布矿山智能... 人民财讯12月24日电,国家矿山安全监察局12月24日公布矿山智能化建设相关激励政策,其中提出,在煤...
    中航基金杨中楷:政策+技术+资... 近日,A股商业航天板块在资本市场热度骤升。中航基金总监助理杨中楷在接受上海证券报记者专访时深入解读商...
    北京:优化政策放宽非京籍家庭购... 新华社北京12月24日电(记者郭宇靖)为贯彻落实中央经济工作会议精神,着力稳定房地产市场,12月24...
    清华招生办:遭冒用名义散布不实... 每经AI快讯,12月24日,清华大学招生办公室发布声明:近日,我办接到多所中学、家长及学生反映,有部...
    北京楼市:三次松绑政策促需求释... 【12月24日消息,自去年9月起北京三次松绑楼市政策】自去年9月以来,北京已三次出台政策松绑楼市。业...
    志邦家居(603801)发布董... 截至2025年12月24日收盘,志邦家居(603801)报收于9.22元,较前一交易日上涨0.44%...
    注意,北京住房限购政策有调整! 24日,北京市住建委网站发布通知,进一步优化调整本市房地产相关政策,全文如下: 北京市住房和城乡建设...
    鑫汇科及子公司陷施工合同纠纷 ... 12月24日,鑫汇科(920267)发布公告,公司及全资子公司鑫汇科电器的部分银行账户资金被冻结,冻...
    北京房地产限购政策调整! | ... 12月24日,北京市住房城乡建设委、市发展改革委、人民银行北京市分行、北京住房公积金管理中心等4部门...