JavaScript-脚本化css

读写css属性

dom.style.prop dom上有一个style属性可以查看更改行间样式。

        <div style="width:100px;height:100px;background-color:red;display:inline-block" > </div>
        <script type="text/javascript">
           var div=document.getElementsByTagName('div')[0];
        </script>

div.style返回了一个类数组,里面装着各种各样的css属性,我们写的属性的确都在里面,这个比较简单吧。

我们也可以更改属性值

我们更改属性值是可以的.


我们把代码改一下:

        <div class='demo' style="height:100px;background-color:red;display:inline-block" > </div>
        <script type="text/javascript">
           var div=document.getElementsByTagName('div')[0];
        </script>
.demo{
    width:100px;
     
}
然后我们通过刚刚的方法来遍历width属性
意料之中,刚刚就说了div只能访问行间样式咯,没有在行间样式写出来即使存在也不会有值

 我们写值也会在行间样式中表现出来

注意:

dom.style.prop可以读写行间样式,没有兼容性问题,碰到float这样的css保留字,那么前面应该加css 譬如cssfloat

复合属性最好拆解(比如border有很多属性,我们就用小驼峰式组和单词一个一个属性进行赋值)

譬如:border="2px solid black";

我们应该换成div.border.borderWidth='2px'等等分开写。

写入的值是字符串


查询计算样式

window.getComputedStyle(ele,null)

第一个填操作dom对象,第二个一般填null也可以填其他的获取伪元素属性点击打开链接

        <div  style="width:100px;height:100px;background-color:red;display:inline-block" > </div>
        <script type="text/javascript">
           var div=document.getElementsByTagName('div')[0];
        </script>

基本把css所有属性都给我们返回了,也是一个类数组,我们同样可以通过相同的方法来返回各种属性,注意这个样式就是显示的样式和前面一个不一样(不是行间的)。

表现出什么就返回什么,这个比较准确。

注意这个不允许写的


返回的值都是绝对值,没有相对单位比如em就会给我们返回多少px

IE8和IE8以下不兼容


IE8和IE8以下查询属性dom.currentStyle(chrome没有办法演示)

样式只能读,返回的不是绝对值,ie独有属性

和上面的调用方法差不多,div.currentStyle.width就行了


我们封装一个方法,在任何浏览器下都可以使用的方法,查询dom元素的某一个属性

           function getStyle(ele,prop) {
               if (window.getComputedStyle) {
                   return window.getComputedStyle(ele,null)[prop];
               }
               else return ele.currentStyle[prop];
           }



猜你喜欢

转载自blog.csdn.net/wust_cyl/article/details/80030167