为了账号安全,请及时绑定邮箱和手机立即绑定

实时检测 DOM 自定义数据属性值的变化,并在发生变化时使用 js 运行函数

实时检测 DOM 自定义数据属性值的变化,并在发生变化时使用 js 运行函数

缥缈止盈 2022-01-13 15:39:05
每次 DOM 元素的自定义数据属性的值发生变化时,我都会尝试运行一个简单的函数。下面是一个例子<div id="myDiv" data-type="type-1">    <!-- Some Content --></div>在上面的 HTML 代码中,我有div一个自定义数据属性,data-type其值是我使用 javascript 更改的。当属性的值根据它所持有的值而改变时,我想启动另一个函数。例如使用 if 语句(不起作用!😒)var myDiv = document.getElementById("myDiv");var myDivAttr = myDiv.getAttribute("data-type");if(myDivAttr == "type-1"){   typeOneFunction();}else if(myDivAttr == "type-2"){   typeTwoFunction();}// and so on...我希望我的问题足够清楚😇😊
查看完整描述

1 回答

?
慕慕森

TA贡献1856条经验 获得超17个赞

您可以使用Mutation Observers实现此目的


// Select the node that will be observed for mutations

const targetNode = document.getElementById('myDiv');


// Options for the observer (which mutations to observe)

const config = { attributes: true };


// Callback function to execute when mutations are observed

const callback = function(mutationsList, observer) {

    // Use traditional 'for loops' for IE 11

    for(let mutation of mutationsList) {

        if (mutation.type === 'attributes') {

            if(myDivAttr == "type-1"){

              typeOneFunction();

             }

             else if(myDivAttr == "type-2"){

               typeTwoFunction();

             }

        }

    }

};


// Create an observer instance linked to the callback function

const observer = new MutationObserver(callback);


// Start observing the target node for configured mutations

observer.observe(targetNode, config);


// Later, you can stop observing

observer.disconnect();

https://developer.mozilla.org/en-US/docs/Web/API/MutationObserver


我没有测试该代码*


查看完整回答
反对 回复 2022-01-13
  • 1 回答
  • 0 关注
  • 201 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信