在没有setInterval的情况下检测类更改

Dav*_*vid 16 html javascript setinterval mutation-observers

我有一个div以编程方式添加的其他类.如何在不使用此setInterval实现的情况下检测类名更改?

setInterval(function() {
    var elem = document.getElementsByClassName('original')[0];
    if (elem.classList.contains("added")) { detected(); }
}, 5500);
Run Code Online (Sandbox Code Playgroud)

MutationObserver?

mot*_*elu 21

您可以使用变异观察者.它现在得到了广泛的支持.

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)
Run Code Online (Sandbox Code Playgroud)
<div id="test">
</div>
Run Code Online (Sandbox Code Playgroud)