知名网站建设定制作为前端你还不懂MutationObserver?那Out了

🐱个人主页:
🙋‍♂️作者简介:知名网站建设定制前端领域新星创作者、知名网站建设定制华为云享专家、知名网站建设定制阿里云专家博主,知名网站建设定制专注于前端各领域技术,知名网站建设定制共同学习共同进步,知名网站建设定制一起加油呀!
💫系列专栏:
📝个人签名:不破不立

🍬目录

🥙前言

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

🥪一、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">0000000</li>			<li class="1">1111111</li>			<li class="2">222222</li>			<li class="3">33333</li>			<li class="4">4444</li>			<li class="5">55555</li>			<li class="6">6666</li>			<li class="7">77777</li>			<li class="8">888888</li>			<li class="9">99999</li>		</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
网站建设定制开发 软件系统开发定制 定制软件开发 软件开发定制 定制app开发 app开发定制 app开发定制公司 电商商城定制开发 定制小程序开发 定制开发小程序 客户管理系统开发定制 定制网站 定制开发 crm开发定制 开发公司 小程序开发定制 定制软件 收款定制开发 企业网站定制开发 定制化开发 android系统定制开发 定制小程序开发费用 定制设计 专注app软件定制开发 软件开发定制定制 知名网站建设定制 软件定制开发供应商 应用系统定制开发 软件系统定制开发 企业管理系统定制开发 系统定制开发