我有一个div
,它以编程方式添加了其他类。如何在不使用此setInterval
实现的情况下检测类名更改?
setInterval(function() {
var elem = document.getElementsByClassName('original')[0];
if (elem.classList.contains("added")) { detected(); }
}, 5500);
MutationObserver?
答案 0 :(得分:15)
您可以使用mutation observer。现在非常widely supported。
var e = document.getElementById('test')
var observer = new MutationObserver(function (event) {
console.log(event)
})
observer.observe(e, {
attributes: true,
attributeFilter: ['class'],
childList: false,
characterData: false
})
setTimeout(function () {
e.className = 'hello'
}, 1000)
<div id="test">
</div>