Javascript动态引用CSS文件的2种方法介绍

新思路:利用js引入新的css文件可以解决大多数动态修改样式的问题,本质是样式覆盖。

 

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

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

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

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

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

 

复制代码代码如下:

 

1

2

3

4

5

6

7

8

9

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

  

 

 

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

 

复制代码代码如下:

 

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

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{ color:#FFFFFF }";

includeStyleElement(styles, "newstyle");

  

 

 

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

关于手贱:

看这段代码:

 

复制代码代码如下:

 

1

2

3

4

5

6

7

8

9

var divObj = document.createElement("div");

divObj.id = "__div";

divObj.innerHTML = "测试js插入DOM和样式";

document.body.appendChild(divObj);

 

var styles = "#__div{ color:#FFFFFF }";

includeStyleElement(styles, "newstyle");

  

 

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

正在修炼的IT大佬

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值