Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

IE 8 and 7 bug when dynamically adding a stylesheet

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?

like image 788
Omar Abid Avatar asked Apr 11 '11 08:04

Omar Abid


1 Answers

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);
like image 104
Alex K Avatar answered Nov 15 '22 10:11

Alex K