JavaScript如何获取css属性

原文:JavaScript如何获取css属性

  在web开发中,很多时候我们需要用JavaScript对网页的样式进行修改,接下来,我们就来看一下我们该如何访问css属性,针对不同情况及案例来进行分析。

 

情况一:css属性位于html标签内

  在实际开发过程中,如果样式表的内容比较少的话,我们通常将css属性封装在html标签中,这时JavaScript访问css属性很直接,通过访问html标签的style属性,修改具体的样式即可完成相应的操作。

  例如:

 1 <!DOCTYPE html>
 2 <html lang="zh-cn">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>styleTest</title>
 6 </head>
 7 <body>
 8
 9 <div style="width: 200px;height: 200px; background: green;" id="mydiv"></div>
10 <input type="button" value="test" onclick="test()">
11 <script type=text/javascript>
12     function test(){
13         var mydiv=document.getElementById('mydiv');
14         mydiv.style.background="red";         // id.style.属性 执行相应的操作
15     }
16 </script>
17
18 </body>
19 </html>

  上述案例通过点击按钮,改变对应div的背景颜色。

 

情况二:css属性在其他文件中

  当css样式表不在html文件中,我们通常会在头部引入css文件名,此时。此时如果我们使用情况一的方法访问,则会发现失败。原因就是此时相应的标签没有style这个属性了,如果我们查看对应标签的style时,会发现是undefined。所以我们需要使用新的方法来访问其属性,网上的方法有很多,在这里我给出我所使用的方法。并给出相应的解释,希望能帮助到大家。

  首先取得定义类的样式表的引用,用document.styleSheet集合实现这个目的,这个集合包含HTML页面中所以的样式表,DOM为每个样式表定义一个CSSRules的集合,这个集合中包含定义在样式表中的所用css规则 (注意:Mozilla和Safari中是cssRulesIE中是rules)。

  具体如下:

  第①步:

    访问获取css文件 ( [0] 表示获取的引入的第一个css文件)

1 var icssrules=document.styleSheets[0].cssRules || document.styleSheets[0].rules;     // 兼容不同浏览器

  第②步:

    获取指定的css属性  ( [0] 表示css文件中的第一个标签的css样式 )

1 var style1=icssrules[0];  

  第③步:

    执行相应操作

1 style1.style.background="red";

 

详细代码如下:

  html文件:

 1 <!DOCTYPE html>
 2 <html lang="zh-cn">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>styleTest</title>
 6     <link rel="stylesheet" href="style.css">
 7 </head>
 8 <body>
 9
10 <div id="mydiv"></div>
11 <input type="button" value="test" onclick="test()">
12 <script type=text/javascript>
13     function test(){
14         var mydiv=document.getElementById('mydiv');
15         var icssrules=document.styleSheets[0].cssRules || document.styleSheets[0].rules;
16         var style1=icssrules[0];
17         style1.style.backgroundColor="red";
18     }
19 </script>
20
21 </body>
22 </html>

  外部css文件:

1 #mydiv {
2     width: 200px;
3     height: 200px;
4     background: green;
5 }

 

  实际效果截图如下:

  点击前:

            

   点击后:

  通过两种方式,可以修改相应的css样式表。针对不同的情况可以借鉴不同的方法。

 

时间: 2024-07-29 17:43:43

JavaScript如何获取css属性的相关文章

JS使用getComputedStyle()方法获取CSS属性值_javascript技巧

在对网页进行调试的过程中,经常会用到js来获取元素的CSS样式,方法有很多很多,现在仅把我经常用的方法总结如下: 1. obj.style:这个方法只能JS只能获取写在html标签中的写在style属性中的值(style="-"),而无法获取定义在<style type="text/css">里面的属性. 复制代码 代码如下: <span style="font-family:Arial;font-size:14px;">

Javascript动态更改Css属性:style样式对照

文章简介:原生js style样式对照. 为了达到某种特殊的效果我们需要用Javascript动态的去更改某一个标签的Css属性.比如:鼠标经过一个图片时我们让图片加一个边框,代码可能是这样: <script type="text/javascript">function imageOver(e) {e.style.border="1px solid red";}function imageOut(e) {e.style.borderWidth=0;}&

浅析JavaScript中的CSS属性及命名规范_javascript技巧

许多CSS样式属性的名字中都有连字符,在JavaScript中,连字符被解释为减号. 因此,CSS2Properties对象的属性名和真正的CSS属性名有点不同. 如果一个CSS属性名含有一个或多个连字符,在JS中则需要删除了连字符,并且原来紧接在连字符后的字母改为大写. 要注意的是float是JS的关键字,所以在JS中float被写作cssFloat与或floatStyle. 下面是CSS自身属性与JavaScript中CSS编码对照表: 盒子标签和属性对照:CodeCSS语法 (不区分大小写

javascript 精确获取样式属性(下)_javascript技巧

width height margin-left margin-right margin-top margin-bottom padding-left padding-right border-left-width border-right-width 渲染模式 top left offsetTop offsetLeft clientTop clientLeft offsetWidth clientWidth scrollWidth 运行代码

js获取某元素的class里面的css属性值代码_javascript技巧

用js如何获取div中css的 margin.padding.height.border等.你可能说可以直接用document.getElementById("id").style.margin获取.但是你说的只能获取直接在标签中写的style的属性,无法获取标签style外的属性(如css文件中的属性).而下面方法则两者值都可以获取.实例效果图如下:   js在获取css属性时如果标签中无style则无法直接获取css中的属性,所以需要一个方法可以做到这点.getStyle(obj,

javascript操作css属性

 今天因需要用到js获取css属性,网上搜了半天都不合适的.有一下几种方法  代码如下: var getstyle = function(elementID,attribute){  obj = document.getElementById(elementID); // 前面是IE后面是html的标准  return obj.currentStyle ? obj.currentStyle[attribute] : document.defaultView.getComputedStyle(ob

Javascript获取CSS伪元素属性的实现代码_javascript技巧

CSS伪元素非常强大,它经常被用来创建CSS三角形提示,使用CSS伪元素可以实现一些简单的效果但又不需要增加额外的HTML标签.有一点就是Javascript无法获取到这些CSS属性值,但现在有一种方法可以获取到: 看看下面的CSS代码: .element:before { content: 'NEW'; color: rgb(255, 0, 0); }.element:before { content: 'NEW'; color: rgb(255, 0, 0); } 为了获取到.element

Javascript获取CSS伪元素的属性

CSS伪元素非常强大,它经常被用来创建CSS三角形提示,使用CSS伪元素可以实现一些简单的效果但又不需要增加额外的HTML标签.有一点就是Javascript无法获取到这些CSS属性值,但现在有一种方法可以获取到: 看看下面的CSS代码: copytext  代码如下 复制代码 .element:before {     content: 'NEW';     color: rgb(255, 0, 0); }.element:before {  content: 'NEW';  color: r

用JavaScript修改CSS属性

 只有写原生的javascript了. 1.用JS修改标签的 class 属性值: class 属性是在标签上引用样式表的方法之一,它的值是一个样式表的选择符,如果改变了 class 属性的值,标签所引用的样式表也就更换了,所以这属于第一种修改方法. 更改一个标签的 class 属性的代码是: document.getElementById( id ).className = 字符串; document.getElementById( id ) 用于获取标签对应的 DOM 对象,你也可以用其它方