JavaScript 检测 DOM 变化(监听 dom 高度变化)

JavaScript 检测 DOM 变化

需要JavaScript MutationObserver 来检测dom变化。

API:MutationObserver

MutationObserver 包含三种方法:

  1. disconnect():防止MutationObserver实例继续接收通知,直到再次调用其 observe() 方法,并且不会再次调用观察者对象中包含的某些函数为止。
  2. observe():将MutationObserver配置为在DOM更改与给定选项匹配时开始通过其替换功能接收通知。
  3. takeRecords():从MutationObserver的通知对象中删除所有待处理的通知,并将它们返回到MutationRecord对象的新数组。
示例:
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>
    <div id="ji">检测此节点的变动</div>
    <script>
        let ji = document.getElementById("ji");
        
        let observe = new MutationObserver(function (mu, ob) {
            console.log("DOM被更新了");
        })
        observe.observe(ji, { attributes: true, childList: true, subtree: true });

        setTimeout(() => {
        
            ji.setAttribute("style", "color:red");
            
            // 停止监听
			observer.disconnect();
			
        }, 2000)
    </script>
</body>

</html>

方法:mutationObserver.observe(target[, options]):

  1. target:DOM树中的一个DOM节点(可能是一个元素)可以观察更改,或者子节点树的根节点可以观察到变化。
  2. options:可选的MutationObserverInit对象。该对象的配置项描述了回调,该回调应将DOM中的某些更改提供给当前的观察者。(调用 observe() 方法时,childList,attributes 或者 characterData 的三个属性中的至少一个必须为true,否则将引发TypeError异常。)

拓展:监听/获取 DOM 高度 getBoundingClientRect


let setin = setInterval(() => {
	let domtop = document.getElementById("ji").getBoundingClientRect().top;
	if(domtop<1){
		clearInterval(setin);
	}
},500)

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一拖再拖 一拖再拖

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值