美文网首页
MutationObserver、IntersectionObs

MutationObserver、IntersectionObs

作者: 风之化身呀 | 来源:发表于2020-12-14 13:48 被阅读0次
  • MutationObserver
    用于监控DOM节点的变化,如 属性变化、子节点增删改、子树的变化等

// 1、选择需要观察变动的节点
const targetNode = document.getElementById('some-id');

// 2、观察器的配置(需要观察什么变动)
const config = { attributes: true, childList: true, subtree: true };

// 3、当观察到变动时执行的回调函数
const callback = function(mutationsList, observer) {
    for(let mutation of mutationsList) {
        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.');
        }
    }
};

// 4、创建一个观察器实例并传入回调函数
const observer = new MutationObserver(callback);

// 5、以上述配置开始观察目标节点
observer.observe(targetNode, config);

// 6、之后,可停止观察
observer.disconnect();
  • IntersectionObserver
    目标A是否与目标B相交
// 图片懒加载的例子
function callback(entry) {
  if(entry[0].isIntersecting) {   // 出现在可视区内(默认 viewport)
    entry[0].target.src = entry[0].target.dataset.src;
    observer.unobserve(entry[0].target);
  }
}

var observer = new IntersectionObserver(callback); // 这里可以指定第二个参数做些定制化配置

var img = document.getElementById('img');

observer.observe(img);

详细解释:https://letswrite.tw/intersection-oserver-basic/

  • ResizeObserver
    专门用来观察DOM元素的尺寸是否发生了变化,不光是窗体resize
var ro = new ResizeObserver( entries => {
  for (let entry of entries) {
    const cr = entry.contentRect;
    console.log('Element:', entry.target);
    console.log(`Element size: ${cr.width}px x ${cr.height}px`);
    console.log(`Element padding: ${cr.top}px ; ${cr.left}px`);
  }
});

// 观察一个或多个元素
ro.observe(eleZxx);

注意:观测的是 contentRect,只有 content 改变(margin,padding不行)才会触发回调
用途:1、原生resize行为的检测,如 textarea 的拉升
2、 感知交互行为的发生(无埋点方案?)
3、感知元素是否显示或隐藏(MutationObserver 有时做不到)
详情:https://www.zhangxinxu.com/wordpress/2020/03/dom-resize-api-resizeobserver/

相关文章

  • MutationObserver、IntersectionObs

    MutationObserver用于监控DOM节点的变化,如 属性变化、子节点增删改、子树的变化等 Interse...

  • dom 修改 更新

    MutationObserver MutationObserver[https://developer.mozil...

  • MutationObserver是什么?

    目录 MutationObserver概览 MutationObserver构造器 MutationObserve...

  • 不“知名”API大集合

    MutationObserver MutationObserver 是一个可以监听DOM结构变化的接口。 Muta...

  • MutationObserver

    链接:https://www.jianshu.com/p/90f042c9e42f作者:凝黛色 MutationO...

  • MutationObserver

    MutationObserver 是一个可以监听DOM结构变化的接口。 官方使用方式示例 示例引用链接 https...

  • MutationObserver

    用于监视DOM树的变更,可兼容到IE11其监听回调属于微任务

  • MutationObserver

    今天在看vue源码nextTick实现部分发现如下代码 判断可用MutationObserver的情况下赋予tim...

  • js之MutationObserver

    百度搜索 mdn MutationObserver

  • MutationObserver用法

    Mutation Observer API 用来监视 DOM 变动。比如节点的增减、属性的变动、文本内容的变动。 ...

网友评论

      本文标题:MutationObserver、IntersectionObs

      本文链接:https://www.haomeiwen.com/subject/jdlppktx.html