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

作者 : 开心源码 本文共2242个字,预计阅读时间需要6分钟 发布时间: 2022-05-11 共82人阅读

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

// 写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>

说明
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是摆设,本站源码仅提供给会员学习使用!
7. 如遇到加密压缩包,请使用360解压,如遇到无法解压的请联系管理员
开心源码网 » js笔记五十三之获取元素样式信息(2)

发表回复