I'm using a MutationObserver to look for added images to a web page. As many images are displayed via the CSS background-image
property, I'm checking the current/computed CSS style in addition to looking for img
tags, for example...
var hasBackgroundImage = function(node) {
var nodeStyle = node.currentStyle || getComputedStyle(node, null);
return (
nodeStyle &&
nodeStyle.backgroundImage &&
nodeStyle.backgroundImage != "none"
);
};
However, it seems there is a delay between a node triggering a mutation event and the CSS rules being applied so there appears to be no backgroundImage
during the mutation event even though there will be at some point later. I noticed this when the code worked during debugging (stepping with breakpoints) but didn't work at runtime. Delaying mutation event processing with setTimeout
also works but to be certain the delay needs to be quite large and changes from page to page (I'm not sure exactly when the CSS rules are guaranteed to be applied). A possible cause may simply be the delayed load or injection of CSS content.
What's the best way to achieve this functionality? I guess I'm after an on-style-change mutation, but I doubt this exists.
This works for me...
Use a mutation observer to catch changes to the style attribute...
This works for both
setAttribute("style", ...)
andelement.style.whatever = something
.Catch new
style
andlink
elements with the mutation observer, add anonload
event and parse applicable nodes...