javascript插入样式

最近做一个项目,需要javascript动态插入样式,结果以前的方法失效了!查了2个小时的原因竟然是自己手贱,这个最后再说!

javascript插入样式在前端开发中应用比较广泛,特别是在修改前端表现和页面换肤的时候。最近做的这个任务是用户在别人的站点上点击一个按钮,就会在别的站点页面下插入一个脚本,执行,这其中包含了样式的插入。

一般情况下javascript动态插入样式有两种,一种页面中引入外部样式,在<head>中使用<link>标签引入一个外部样式文件,另一种是在页面中使用<style>标签插入页面样式(这里说的不是style属性)。

一、页面中引入外部样式:

在<head>中使用<link>标签引入一个外部样式文件,这个比较简单,各个主流浏览器也不存在兼容性问题:

[code=”javascript”]

function includeLinkStyle(url) {
var link = document.createElement(“link”);
link.rel = “stylesheet”;
link.type = “text/css”;
link.href = url;
document.getElementsByTagName(“head”)[0].appendChild(link);
}

includeLinkStyle(“http://css.sodao.com/home/css/reset.css?v=20101227”);

[/code]

但是在我目前做的这个项目中本身应用的样式非常少,直接用引入一个外部样式文件似乎不合适,所以我选择了第二种方案,在页面中使用<style>标签插入页面样式。

二、使用<style>标签插入页面样式:

这种方式在各个主流浏览器存在兼容性问题,像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>标签内;

[code=”javascript”]

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

[/code]

这样页面中的元素就能直接应用样式了,不管你的这些元素是不是通过脚本追加的。

关于手贱:

看这段代码:

[code=”javascript”]

var divObj = document.createElement(“div”);
divObj?.id = “__div”;
divObj?.innerHTML=”测试js插入DOM和样式”;
document.body.appendChild(divObj?);

var styles = “#__div{background-color: #FF3300; color:#FFFFFF }”;
includeStyleElement(styles,”newstyle”);

[/code]

前面说了这个项目是用户在别人的站点上点击一个按钮,就会在别的站点页面下插入一个脚本,执行,这其中包含了样式的插入,我为了尽可能的保证我创建的元素ID唯一性,手贱在元素ID前加了“__”,表示私有防止冲突。结果悲剧了,IE6,IE7 class和id的命名不能以下划线开头(“_”),竟然把这个给忘了!花了两个小时才找到原因。悲剧啊!得出一个结论!做前端千万不能手贱!

赞(0) 打赏
未经允许不得转载:WEB前端开发 » javascript插入样式

评论 7

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址
  1. #-49

    学习了. 从来没用过 “_” 还不知道这个会引起杯具.
    “做前端千万不能手贱!” 真理~

    大宝7年前 (2012-01-30)回复
  2. #-48

    局部样式变化 通过class名改变是不是会更简单一些

    tina7年前 (2012-01-31)回复
  3. #-47

    想跟您换个连接,可以吗?等待回复!http://echowong.info/

    Echo7年前 (2012-01-31)回复
  4. #-46

    习惯用jquery库和kissy库了,都很好的解决了插入样式的兼容性等问题了

    crazyleaves7年前 (2012-01-31)回复
  5. #-45

    直接用 style.innerHTML = cssText
    ^_^

    azrael7年前 (2012-02-02)回复
  6. #-44

    坚决不能手贱了以后 呵呵

    自由人7年前 (2012-02-05)回复

前端开发相关广告投放 更专业 更精准

联系我们

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏