J'ai un div
qui a des classes supplémentaires ajoutées par programme. Comment puis-je détecter le changement de nom de classe sans utiliser cette implémentation setInterval
?
setInterval(function() {
var elem = document.getElementsByClassName('original')[0];
if (elem.classList.contains("added")) { detected(); }
}, 5500);
MutationObserver?
Vous pouvez utiliser un observateur de mutation . C'est assez largement supporté de nos jours.
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>