亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

js筆記五十三之獲取元素樣式信息(2)

標簽:
JavaScript

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

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



作者:uplyw
链接:https://www.jianshu.com/p/e6f90568336d


點擊查看更多內容
TA 點贊

若覺得本文不錯,就分享一下吧!

評論

作者其他優質文章

正在加載中
  • 推薦
  • 評論
  • 收藏
  • 共同學習,寫下你的評論
感謝您的支持,我會繼續努力的~
掃碼打賞,你說多少就多少
贊賞金額會直接到老師賬戶
支付方式
打開微信掃一掃,即可進行掃碼打賞哦
今天注冊有機會得

100積分直接送

付費專欄免費學

大額優惠券免費領

立即參與 放棄機會
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號

舉報

0/150
提交
取消