时间:2021-05-28
再记录一下 Javascript访问样式表
Javascript可以访问网页中元素的style属性,例如:
<div id="main" style="background-color:red"></div>
通过js访问style属性
alert(document.getElementById("main").style.backgroundColor);
通过js改变style属性
document.getElementById("main").style.backgroundColor="blue";
以上代码是我们所熟悉的,但通常我们用样式表来控制元素的外观属性,例如:
JS控制CSS #main { margin-left:200px; margin-top:70px; width:200px; height:100px; background-color999999; border:1px solid #666666; } Show [Ctrl+A 全选 注:引入外部Js需再刷新一下页面才能执行]
此时如果我们再使用 alert(document.getElementById("main").style.backgroundColor);
则只能获得一个空值,所以只能通过js去访问样式表了.
document.styleSheets可以获得样式表的集合,因为浏览器之间有很大不同,访问样式表的单独规则也不同.DOM为每一个样式表指定一个cssRules集合,Mozilla和Safari正确实现了这个标准,不过可惜IE中定义这个集合为rules,因此可以使用以下代码来获得正确的对象:
var oCssRules=document.styleSheets[0].cssRules||document.styleSheets[0].rules;
这样就可以获得不同浏览器的CSS集合了.
通过以下JS代码来获得样式表中的样式:
复制代码 代码如下:
function GetCSS()
{
var oCssRules=document.styleSheets[0].cssRules||document.styleSheets[0].rules;
alert(oCssRules[0].style.backgroundColor);
}
styleSheets[0]表示第一个样式表引用,oCssRules[0]表示第一个样式规则(即#main{}的内容),通过style属性来访问具体的规则.
同理,更改该样式表规则代码如下:
复制代码 代码如下:
function SetCSS()
{
var oCssRules=document.styleSheets[0].cssRules||document.styleSheets[0].rules;
oCssRules[0].style.backgroundColor="red";
oCssRules[0].style.marginLeft="20px";
oCssRules[0].style.marginTop="20px";
}
但是需要注意的是,因为很多元素有可能关联同一个样式表,所以改变时需要慎重.
除了元素的style对象和css规则外,每个元素还有一个最终样式,最终样式用来告诉我们元素最后是如何显示在屏幕上的,也就是style和css重合计算后的样式.IE和DOM有两种方式来访问此样式,IE中通过currentStyle属性,DOM中使用getComputedStyle()方法.
JS获得最终样式的方法如下:
复制代码 代码如下:
function GetFinalCSS()
{
var oDiv=document.getElementById("main");
//访问style属性
alert(oDiv.style.backgroundColor);
//IE方法
alert(oDiv.currentStyle.backgroundColor);
//DOM方法,第二个参数为伪元素,如:hover,first-leeter之类
//alert(document.defaultView.getComputeStyle(oDiv,null).backgroundColor);
}
我经常使用currentStyle来获得样式,省去了访问样式表的麻烦
需要注意的是currentStyle是只读属性,不能够对其赋值,因为其是多种样式综合计算后的样式规则,这点并不难理解.
对于getComputedStyle方法,可以通过document.defaultView来调用(IE和Safari不支持此方法).所以,当使用getComputedStyle方法时,最好在多个浏览器上进行测试.
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
JavaScript可以同样式进行交互,你可以通过编写程序来动态改变文档上元素的样式。有三种方法可以实现这样的效果:控制样式表—可以添加、删除、修改样式表。控制
本文实例讲述了JavaScript动态加载样式表的方法。分享给大家供大家参考。具体如下:如果需要更换皮肤,我们可以通过JS代码动态加载皮肤的样式表,下面的代码就
css设置超链接样式是通过伪类来实现的(1):link:设置a对象在未被访问前的样式表属性。(2):visited:设置a对象在其链接地址已被访问过时的样式表属
复制代码代码如下:Inserttitlehere.div_1{color:blue;font-size:20px;}内部样式表内联式样式表外部样式表
JavaScript访问CSS属性的方式总体说来有两种:“通过元素访问”、“直接访问样式表”。另外访问样式的时候有一个不可忽略的问题——运行时样式。1.通过元素