美文网首页程序员js笔记笔记
js笔记五十三之获取元素样式信息(2)

js笔记五十三之获取元素样式信息(2)

作者: uplyw | 来源:发表于2018-06-26 22:00 被阅读43次

如何避免获取复合值时浏览器之间差异

// 写CSS的时候第一步初始化默认样式,避免浏览器之间的差异 -> 
// 不仅如此,而且写默认样式对于js以后获取到的结果统一也是有帮助的

function getCSS(curEle, attr){
    var val = null;
    if("getComputedStyle" in window){
        val=window.getComputedStyle(curEle,null)[attr];
    }else{
        val = curEle.currentStyle[attr];
    }
    return val;
}
// -> 标准浏览器和IE浏览器获取的结果还是不一样的 -> 对于部分样式属性,不同的浏览器获取的结果不一样,
// 主要是由于getComputedStyle和currentStyle在某些方面不一样
console.log(getCss(box,"border")); // undefined
// 把复合值拆开来写能避免这一问题  
console.log(getCss(box,"borderTopWidth")); // 10px

第一次升级: 把获取到的样式值"单位去掉"

function getCSS(curEle, attr){
    var val = null;
    if("getComputedStyle" in window){
        val=window.getComputedStyle(curEle,null)[attr];
    }else{
        val = curEle.currentStyle[attr];
    }
    return parseFloat(val); 
    // -> 去单位这样写不行,对于某些样式属性的值是不能去单位的;
    // -> 例如float, position, margin, padding, border的复合值等等...
}
console.log(getCss(box,"width"));
// 利用正则
function getCSS(curEle, attr){
    var val = null, reg = null;
    if("getComputedStyle" in window){
        val=window.getComputedStyle(curEle,null)[attr];
    }else{
        val = curEle.currentStyle[attr];
    }
    reg = /^(-?\d+(\.\d+)?)(px|pt|rem|em)?$/i;
    return reg.test(val) ? parseFlort(val) : val;
}
console.log(getCss(box,"width"));

第二次升级: 有些样式属性在不同的浏览器中是不兼容的,例如: opacity

// opacity:0.1; 透明度, 在IE6~8中不兼容
// filter:alpha(opacity=10); 不兼容 使用滤镜来处理; 

function getCSS(curEle, attr){
    var val = null, reg = null;
    if("getComputedStyle" in window){
        val=window.getComputedStyle(curEle,null)[attr];
    }else{
        // IE6~8;
        // 如果传递进来的结果是opacity, 说明要获取的是透明度, 但是在IE6~8下获取透明度需要使用filter
        if(attr === "opacity"){
            val = curEle.currentStyle["filter"]; // -> "alpha(opacity=10)"
            // 把获取到的结果进行剖析,获取里面的数字,让数字除以100才和标准的浏览器保持一致
            reg = /^alpha\(opacity=(\d+(?:\.\d+)?)\)$/i;
            val = reg.test(val)?reg.exec(val)[1]/100:1;
        }else{
            val = curEle.currentStyle[attr];
        }
    }
    reg = /^(-?\d+(\.\d+)?)(px|pt|rem|em)?$/i;
    return reg.test(val) ? parseFlort(val) : val;
}
console.log(getCss(box,"opacity"));

补充: css伪类元素获取

<style type="text/css">
    #box{
        width: 300px;
        padding: 30px;
        border: 1px dashed #ddd;
        margin: 50px auto;
    }
    #box:before{
        display: block;
        content: "标题";
        background: lightgreen;
        line-height: 1.5;
        text-align: center;
    }
    #box:after{
        display: block;
        content: "结尾";
        background: lightgreen;
        line-height: 1.5;
        text-align: center;
    }
</style>
<div id="box">这是一段文字这是一段文字这是一段文字这是一段文字这是一段文字这是一段文字这是一段文字</div>
<script>
    var box = document.getElementById("box")
    console.log(window.getComputedStyle(box, "before").content)
    console.log(window.getComputedStyle(box, "after").lineHeight)
</script>

相关文章

  • js笔记五十三之获取元素样式信息(2)

    如何避免获取复合值时浏览器之间差异 第一次升级: 把获取到的样式值"单位去掉" 第二次升级: 有些样式属性在不同的...

  • js笔记五十二之获取元素样式信息(1)

    获取元素的某一个具体样式属性值 元素.style.属性名 需要我们把元素的样式都写在行内样式上才可以(写在样式表中...

  • 获取元素大小和位置的五种方式

    一、直接获取元素样式属性值 运用之前在JS如何获取元素样式?这篇文章中提到的三种获取元素样式方法便可获取元素大小和...

  • SVG操作笔记

    Js操作svg笔记 js获取svg里面某个标签元素的位置信息 event.target.getBBox();返回该...

  • dom操作css

    解决浏览器兼容,获取div样式 页面样式: 通过js修改元素样式: 读取样式: 读取正在显示样式: 语法:元素.c...

  • JS盒子模型

    JS盒子模型指的是通过JS中提供的一些列属性和方法,获取页面中元素的样式等信息值 该元素的原型链:div#box...

  • JS盒子模型常用属性

    JS盒子模型指的是通过JS中提供的一系列的属性和方法,获取页面中元素的样式信息值 client系列/offset系...

  • JS笔记

    JS笔记 js顺序 1,获取标签,元素 2,确定事件 3,具体操作 1, onmouseover="wenzi.s...

  • 如何用js改变伪元素样式

    通常设置伪元素的样式直接用CSS很方便 可是有时候想用js动态的去改变伪元素的样式,但是js获取不到伪元素,这就很...

  • 筛选商品案例

    案例样式: 1. HTML结构 2. JS代码部分 2.1 获取相应的元素 2.2 使用 forEach 遍历数据...

网友评论

    本文标题:js笔记五十三之获取元素样式信息(2)

    本文链接:https://www.haomeiwen.com/subject/fqhvyftx.html