zoukankan      html  css  js  c++  java
  • js基础(样式)

     修改样式:

    /*
                         * 通过JS修改元素的样式:
                         *     语法:元素.style.样式名 = 样式值
                         * 
                         * 注意:如果CSS的样式名中含有-,
                         *         这种名称在JS中是不合法的比如background-color
                         *         需要将这种样式名修改为驼峰命名法,
                         *         去掉-,然后将-后的字母大写
                         * 
                         * 我们通过style属性设置的样式都是内联样式,
                         *     而内联样式有较高的优先级,所以通过JS修改的样式往往会立即显示
                         * 
                         * 但是如果在样式中写了!important,则此时样式会有最高的优先级,
                         *     即使通过JS也不能覆盖该样式,此时将会导致JS修改样式失效
                         *     所以尽量不要为样式添加!important
                         * 
                         * 
                         * 
                         */
                        box1.style.width = "300px";
                        box1.style.height = "300px";
                        box1.style.backgroundColor = "yellow";

     读取样式:

                        /*
                         *     语法:元素.style.样式名
                         * 
                         * 通过style属性设置和读取的都是内联样式
                         *     无法读取样式表中的样式
                         */
                /*
                         * 获取元素的当前显示的样式
                         *     语法:元素.currentStyle.样式名
                         * 它可以用来读取当前元素正在显示的样式
                         *     如果当前元素没有设置该样式,则获取它的默认值
                         * 
                         * currentStyle只有IE浏览器支持,其他的浏览器都不支持
                         */
                        alert(box1.currentStyle.width);
    /*
                         * 在其他浏览器中可以使用
                         *         getComputedStyle()这个方法来获取元素当前的样式
                         *         这个方法是window的方法,可以直接使用
                         * 需要两个参数
                         *         第一个:要获取样式的元素
                         *         第二个:可以传递一个伪元素,一般都传null
                         * 
                         * 该方法会返回一个对象,对象中封装了当前元素对应的样式
                         *     可以通过对象.样式名来读取样式
                         *     如果获取的样式没有设置,则会获取到真实的值,而不是默认值
                         *     比如:没有设置width,它不会获取到auto,而是一个长度
                         * 
                         * 但是该方法不支持IE8及以下的浏览器
                         * 
                         * 通过currentStyle和getComputedStyle()读取到的样式都是只读的,
                         *     不能修改,如果要修改必须通过style属性
                         */
                       
                        //正常浏览器的方式
                        alert(getComputedStyle(box1,null).backgroundColor);
                        
                        //IE8的方式
                        alert(box1.currentStyle.backgroundColor);
                        
                        alert(getStyle(box1,"width"));
    /*
                 * 定义一个函数,用来获取指定元素的当前的样式
                 * 参数:
                 *         obj 要获取样式的元素
                 *         name 要获取的样式名
                 */
                
                function getStyle(obj , name){
                    
                    if(window.getComputedStyle){
                        //正常浏览器的方式,具有getComputedStyle()方法
                        return getComputedStyle(obj , null)[name];
                    }else{
                        //IE8的方式,没有getComputedStyle()方法
                        return obj.currentStyle[name];
                    }
                    
                    //return window.getComputedStyle?getComputedStyle(obj , null)[name]:obj.currentStyle[name];
                    
                }

    其他的样式相关的属性:

    #box1{
                     100px;
                    height: 100px;
                    background-color: red;
                    padding: 10px;
                    border: 10px solid yellow;
                }
    /*
                         * clientWidth
                         * clientHeight
                         *     - 这两个属性可以获取元素的可见宽度和高度
                         *     - 这些属性都是不带px的,返回都是一个数字,可以直接进行计算
                         *     - 会获取元素宽度和高度,包括内容区和内边距
                         *  - 这些属性都是只读的,不能修改
                         */
                        alert(box1.clientWidth);
                        alert(box1.clientHeight);
    /*
                         * offsetWidth
                         * offsetHeight
                         *     - 获取元素的整个的宽度和高度,包括内容区、内边距和边框
                         */
                        alert(box1.offsetWidth);
    
    
    
    /*
                         * offsetParent
                         *     - 可以用来获取当前元素的定位父元素
                         *  - 会获取到离当前元素最近的开启了定位的祖先元素
                         *         如果所有的祖先元素都没有开启定位,则返回body
                         */
                        var op = box1.offsetParent;
    
    
    /*
                         * offsetLeft
                         *     - 当前元素相对于其定位父元素的水平偏移量
                         * offsetTop
                         *     - 当前元素相对于其定位父元素的垂直偏移量
                         */
                        
                        alert(box1.offsetLeft);
    
    
    
    /*
                         * scrollWidth
                         * scrollHeight
                         *     - 可以获取元素整个滚动区域的宽度和高度
                         */
                        alert(box4.clientHeight);
                        alert(box4.scrollWidth);

     

           

  • 相关阅读:
    spring无法接收上传文件
    springcloud feign增加熔断器Hystrix
    mybatis调用存储过程(@Select方式)
    spring在注解标注的方法上加切面
    java注解Annotation
    java包装类
    JZ-C-43
    JZ-C-42-Plus
    JZ-C-42
    JZ-C-41-Plus
  • 原文地址:https://www.cnblogs.com/lzb0803/p/9028325.html
Copyright © 2011-2022 走看看