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


Posted in Javascript onJune 06, 2014

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

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

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

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

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

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.3water.com/home/css/reset.css?v=20101227");

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

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

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

关于手贱:

看这段代码:

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的命名不能以下划线开头(“_”),竟然把这个给忘了!花了两个小时才找到原因。悲剧啊!得出一个结论!做前端千万不能手贱!

Javascript 相关文章推荐
使两个iframe的高度与内容自适应,且相等
Nov 20 Javascript
[原创]保存的js无法执行的解决办法
Feb 25 Javascript
基于JavaScript实现继承机制之构造函数+原型链混合方式的使用详解
May 07 Javascript
javascript实现控制文字大中小显示
Apr 28 Javascript
基于JQuery实现图片轮播效果(焦点图)
Feb 02 Javascript
关于两个jQuery(js)特效冲突的bug的解决办法
Sep 04 Javascript
jQuery实现的表格展开伸缩效果实例
Sep 07 Javascript
Vue.js 递归组件实现树形菜单(实例分享)
Dec 21 Javascript
input获取焦点时底部菜单被顶上来问题的解决办法
Jan 24 Javascript
Vue中使用vee-validate表单验证的方法
May 09 Javascript
JavaScript中常见内置函数用法示例
May 14 Javascript
关于antd tree 和父子组件之间的传值问题(react 总结)
Jun 02 Javascript
jquery 隐藏与显示tr标签示例代码
Jun 06 #Javascript
Node.js中对通用模块的封装方法
Jun 06 #Javascript
JavaScript中对循环语句的优化技巧深入探讨
Jun 06 #Javascript
jquery修改网页背景颜色通过css方法实现
Jun 06 #Javascript
jquery动态调整div大小使其宽度始终为浏览器宽度
Jun 06 #Javascript
JavaScript也谈内存优化
Jun 06 #Javascript
Javascript中的delete操作符详细介绍
Jun 06 #Javascript
You might like
php检测用户是否用手机(Mobile)访问网站的类
2014/01/09 PHP
php中文乱码怎么办如何让浏览器自动识别utf-8
2014/01/15 PHP
PHP中防止SQL注入方法详解
2014/12/25 PHP
记录Yii2框架开发微信公众号遇到的问题及解决方法
2018/07/20 PHP
PHP实现微信退款的方法示例
2019/03/26 PHP
laravel 出现command not found问题的解决方案
2019/10/23 PHP
[原创]后缀就扩展名为js的文件是什么文件
2007/12/06 Javascript
javascript天然的迭代器
2010/10/29 Javascript
菜鸟javascript基础资料整理2
2010/12/06 Javascript
自己做的模拟模态对话框实现代码
2012/05/23 Javascript
javascript学习笔记(十二) RegExp类型介绍
2012/06/20 Javascript
根据IP的地址,区分不同的地区,查看不同的网站页面的js代码
2013/02/26 Javascript
解析js中获得父窗口链接getParent方法以及各种打开窗口的方法
2013/06/19 Javascript
了解了这些才能开始发挥jQuery的威力
2013/10/10 Javascript
js中AppendChild与insertBefore的用法详细解析
2013/12/16 Javascript
JQuery中的事件及动画用法实例
2015/01/26 Javascript
bootstrap fileinput插件实现预览上传照片功能
2018/01/23 Javascript
小程序富文本提取图片可放大缩小
2020/05/26 Javascript
[01:33:59]真人秀《加油 DOTA》 第六期
2014/09/09 DOTA
[03:37]2016完美“圣”典 风云人物:Mikasa专访
2016/12/07 DOTA
[56:41]iG vs Winstrike 2018国际邀请赛小组赛BO2 第二场
2018/08/17 DOTA
django如何实现视图重定向
2019/07/24 Python
使用python写一个自动浏览文章的脚本实例
2019/12/05 Python
Python标准库itertools的使用方法
2020/01/17 Python
在pycharm中关掉ipython console/PyDev操作
2020/06/09 Python
关于HTML5的22个初级技巧(图文教程)
2012/06/21 HTML / CSS
ECHT官方网站:男女健身服
2020/02/14 全球购物
职业教育毕业生求职信
2013/11/09 职场文书
销售经理工作职责范文
2013/12/03 职场文书
车队司机个人自我鉴定
2014/04/17 职场文书
教师对照四风自我剖析材料
2014/09/30 职场文书
沂蒙六姐妹观后感
2015/06/08 职场文书
重阳节活动主持词
2015/07/04 职场文书
python实现图片批量压缩
2021/04/24 Python
Python基础详解之描述符
2021/04/28 Python
python实现语音常用度量方法的代码详解
2021/05/25 Python