动态添加样式表时IE 8和7的错误

时间:2011-04-11 08:37:52

标签: internet-explorer coding-style

我有以下代码

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);

这适用于所有浏览器(也是IE 9)但是对于IE7和IE8,我收到以下错误

  

SCRIPT600:未知的运行时错误

错误指向

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

怎么了?

1 个答案:

答案 0 :(得分:10)

你可以这样试试

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);