javascript插入样式
来源:互联网 发布:多益网络和37和4399 编辑:程序博客网 时间:2024/06/05 16:02
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]
这样页面中的元素就能直接应用样式了,不管你的这些元素是不是通过脚本追加的
- JavaScript插入动态样式
- javascript插入样式
- 用javascript插入样式
- JavaScript 样式
- JavaScript 样式
- JavaScript:样式
- css插入样式表
- css样式插入
- Umbraco 官方技术文档 翻译 十、 插入媒体 和 使用样式表和javascript
- 运用innerHTML的插入样式
- javascript改变样式
- javascript改变样式
- javascript与TAB样式
- JavaScript 取得最终样式
- JavaScript 字符串样式设计
- javascript static样式
- JavaScript操作CSS样式
- JavaScript 控制样式 CSS
- apt命令
- android创建签名
- 将WebService编译成dll
- 与大二学生讨论专业学习
- 表视图
- javascript插入样式
- ElasticSearch Shard Placement Control
- 修改adb devices列表中设备串号名称
- C语言技巧
- centos开机界面的自己订制
- 定制单元格
- Booting Xen
- Cookie 和 Session
- 【amazing cocos2d-x 3.0之十四】内存管理(2):纹理缓存(Texture Cache)