IE 8 and 7 bug when dynamically adding a styleshee

2020-02-12 06:38发布

问题:

I have the following code

var style = document.createElement('style');
style.setAttribute("type", "text/css");
if (style.textContent) { // FF, Safari
    style.textContent = this.arg.css;
} else {
    style.innerHTML = this.arg.css;// FF, IE
}
document.getElementsByTagName('head')[0].appendChild(style);

This works fine in all browsers (also IE 9) but for IE7 and IE8, I get the following error

SCRIPT600: Unknown runtime error

The error points to the line

    style.innerHTML = this.arg.css;// FF, IE

What's wrong?

回答1:

you can try this way

var style = document.createElement('style');
var text = this.arg.css;
style.setAttribute("type", "text/css");
if (style.styleSheet) {   // for IE
    style.styleSheet.cssText = text;
} else {                // others
    var textnode = document.createTextNode(text);
    style.appendChild(textnode);
}
var h = document.getElementsByTagName('head')[0];
h.appendChild(style);