我们以下面这个典型的<link>元素为例:

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

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

复制代码 代码如下:

复制代码 代码如下:

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

与动态添加嵌入式脚本类似,重写后的代码使用了try-catch语句来捕获IE抛出的错误,然后再使用针对IE的特殊方式来设置样式。一次通用的解决方案如下:

复制代码 代码如下:

复制代码 代码如下:

您可能感兴趣的文章:

  • javascript插入样式实现代码
  • ExtJS自定义主题(theme)样式详解
  • jsp页面中插入css样式的三种方法总结
  • js动态修改整个页面样式达到换肤效果
  • jquery
    mobile页面跳转后样式丢失js失效的解决方法
  • 点击button获取text内容并改变样式的js实现
  • js实现class样式的修改、添加及删除的方法
  • 使用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(“”);

<link rel=”stylesheet” type=”text/css”
href=”style.css”>使用DOM代码可以很容易的动态创建出这个元素:

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

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

另一种定义样式的方式是使用<style>元素来包含嵌入式CSS,如下所示:

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

复制代码 代码如下:

复制代码 代码如下:

这样页面中的元素就能直接应用样式了,不管你的这些元素是不是通过脚本追加的。
关于手贱:
看这段代码:

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

Author

发表评论

电子邮件地址不会被公开。 必填项已用*标注