javascript插入样式在前端开发中应用比较广泛,特别是在修改前端表现和页面换肤的时候。 一般情况下javascript动态插入样式有两种,一种页面中引入外部样式,在中使用标签引入一个外部样式文件,另一种是在页面中使用标签插入页面样式(这里说的不是style属性)。</p> <p><strong>一、页面中引入外部样式:</strong></p> <p>在<head>中使用<link>标签引入一个外部样式文件,这个比较简单,各个主流浏览器也不存在兼容性问题:</p><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:js;toolbar:false">function includeLinkStyle(url) { var link = document.createElement("link"); link.rel = "stylesheet"; link.type = "text/css"; link.href = url; document.getElementsByTagName("head")[0].appendChild(link); }</pre><div class="contentsignin">登录后复制</div></div><p><span style="line-height: 1.76em;">直接用引入一个外部样式文件似乎不合适,所以选择了第二种方案,在页面中使用<style>标签插入页面样式。</span><br/></p><p><strong>二、使用<style>标签插入页面样式:</strong></p><p>这种方式在各个主流浏览器存在兼容性问题,像firefox等标准浏览器无法直接获取设置styleSheet的cssText值,标准浏览器下只能使用document.styleSheets[0].cssRules[0].cssText单个获取样式;同时使用:document.styleSheets[0].cssRules[0].cssText=newcssText;页面不会自动更新样式,必须使用:document.styleSheets[0].cssRules[0].style.cssText=newcssText;这点似乎没坑爹的IE来的人性化和简便。YUI中使用了一个很好的办法:style.appendChild(document.createTextNode(styles));采用createTextNode将样式字符串添加到<style>标签内;</p><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:js;toolbar:false">function includeStyleElement(styles, styleId) { if (document.getElementById(styleId)) { return } var style = document.createElement("style"); style.id = styleId; //这里最好给ie设置下面的属性 /*if (isIE()) { style.type = "text/css"; style.media = "screen" }*/ (document.getElementsByTagName("head")[0] || document.body).appendChild(style); if (style.styleSheet) { //for ie style.styleSheet.cssText = styles; } else { //for w3c style.appendChild(document.createTextNode(styles)); } } var styles = "#div{background-color: #FF3300; color:#FFFFFF }"; includeStyleElement(styles, "newstyle");</pre><div class="contentsignin">登录后复制</div></div><p>这样页面中的元素就能直接应用样式了,不管你的这些元素是不是通过脚本追加的。</p>