js监听页面元素变化

window.MutationObserver(callback)

该接口用来观察节点变化,MutationObserver是一个构造器,接收一个回调函数callback用来处理节点变化时所做的操作。

var observe = new MutationObserver(mutationCallback);

MutationObserver对象有三个方法,分别如下:

observe:设置观察目标,接受两个参数:target:观察目标,config:设置观察选项

    var observe = new MutationObserver(mutationCallback);

     observe.observe(dom, config);// 后面介绍config的配置

disconnect:阻止对目标节点的监听。

   var observe = new MutationObserver(mutationCallback);

   observe.disconnect();

takeRecords:取出记录队列中的记录。它的一个作用是当你不想对节点变化立刻做出反应,过段时间再显示改变了节点的内容。

    var observe = new MutationObserver(mutationCallback);

    var record = observe.takeRecords();

config配置(只介绍常用的几个):

let config = {

    attributes: true, //目标节点的属性变化

    childList: true, //目标节点的子节点的新增和删除

    characterData: true, //如果目标节点为characterData节点(一种抽象接口,具体可以为文本节点,注释节点,以及处理指令节点)时,也要观察该节点的文本内容是否发生变化

    subtree: true, //目标节点所有后代节点的attributes、childList、characterData变化

};

代码示例

 <div id="h">123123</div>

    <script>

            window.onload=function(){

                // Firefox和Chrome早期版本中带有前缀

                var MutationObserver = window.MutationObserver || window.WebKitMutationObserver || window.MozMutationObserver

                // 选择目标节点

                var target = document.querySelector('#h'); 

                // 创建观察者对象

                var observer = new MutationObserver(function(mutations) {  

                    mutations.forEach(function(mutation) { 

                        console.log(mutation); 

                    }); 

                }); 

                // 配置观察选项:

                var config = { attributes: true, childList: true, characterData: true } 

                // 传入目标节点和观察选项

                observer.observe(target, config); 

                // 随后,你还可以停止观察

                // observer.disconnect();

                document.getElementById('h').onclick=function(){

                // this.style.width="50px"

                this.innerHTML = "888888"

                }

            }

    </script>

原文链接:https://blog.csdn.net/weixin_42420703/article/details/98334813

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 让元素显示滚动到屏幕可视区: 监听右键菜单并阻止其显示,然后可以显示自定义菜单 监听窗口关闭事件,弹出提示向用户再...
    Gary嘉骏阅读 330评论 0 0
  • 方便起见不分parameter[形参,出现在函数定义中]和argument[实参,其值为传入函数的值],一律当作a...
    东月三二阅读 399评论 0 0
  • 目前 JavaScript 仍是前端开发的灵魂,各种层出不穷的框架其实都是与底层相关。 开始之前,借前端三元同学的...
    WEB前端含光阅读 317评论 0 0
  • 一、概念介绍 Vue.js和React.js分别是目前国内和国外最火的前端框架,框架跟类库/插件不同,框架是一套完...
    刘远舟阅读 1,081评论 0 0
  • 导语:前段时间做某系统审核后台,出现了审核人员截图把内容外泄露的情况,虽然截图内容不是特别敏感,但是安全问题还是不...
    李亚_45be阅读 1,197评论 0 0