rem轉(zhuǎn)rpx前端代碼

效果


image.png

代碼:

<!DOCTYPE html>
<html>
 
    <head>
        <meta charset="UTF-8">
        <title></title>
        <script type="text/javascript" src="../layui/jquery-3.2.1.min.js"></script>
        <style>
            div#newCss {
                border: 1px solid #999;
                width: 504px;
                height: 140px;
            }
        </style>
    </head>
 
    <body>
        <h4>rem樣式</h4>
        <textarea id="css" cols="60" rows="10"></textarea>
        <br />
        <input type="button" value="rem轉(zhuǎn)換rpx" onclick="rem2rpx()" />
        <h4>轉(zhuǎn)換后的樣式</h4>
        <div id="newCss"></div>
        <input id="aaa">
        <input id="bbb">
        <script type="text/javascript">
            function rem2rpx() {
                var oldCss = document.getElementById("css").value.trim(); //".similar_recommend .title{margin:.3rem 0 0;padding-top:.4rem;color:#666;font-size:.28rem;}"
                //對(duì)原樣式根據(jù)rem進(jìn)行拆分成數(shù)組,這樣除了最后一個(gè)元素,數(shù)組前邊的幾個(gè)元素都是以原rem樣式數(shù)值結(jié)尾
                //拆分后的格式:[".similar_recommend{background:#fff;border-radius:.1", ";height:7.4", ";margin-top:-.3", "}"]
                var newCssArr = oldCss.split("rem")
                var newCss = "" //轉(zhuǎn)換后新的樣式變量
                for(var i in newCssArr) {
                    if(i < newCssArr.length - 1) {
                        //非最后一個(gè)元素,對(duì)字符串按照:再次拆分,把rem樣式的數(shù)值分離出來(lái)進(jìn)行轉(zhuǎn)換
                        var str = newCssArr[i]
                        var idx = str.lastIndexOf(':')
                        var prevStr = str.substring(0, idx + 1)
                        var nextStr = "" //nextStr格式為    -.3 , -3 , 3 , .3
                        if(str.indexOf('-.') > -1) {
                            //nextStr格式為-.3rem或-3rem
                            nextStr = str.substring(str.indexOf(':-') + 2, str.length)
                            //nextStr格式為.3rem或3rem
                            if(nextStr.indexOf('.') > -1) {
                                nextStr = "0" + nextStr
                            }
                            nextStr = "-" + parseInt(nextStr * 100) + "rpx"
                        } else {
                            nextStr = str.substring(idx + 1, str.length)
                            //處理 nextStr="1px .2"的情況
                            var index = nextStr.indexOf(' ')
                            if(index >= 0) {
                                let str1 = nextStr.substring(0, index)
                                let str2 = nextStr.substring(index + 1, nextStr.length)
                                str2 = str2.indexOf('.') > -1 ? "0" + str2 : str2
                                str2 = parseInt(str2 * 100) + "rpx"
                                nextStr = str1 + ' ' + str2
                            } else {
                                nextStr = nextStr.indexOf('.') > -1 ? "0" + nextStr : nextStr
                                nextStr = parseInt(nextStr * 100) + "rpx"
                            }
                        }
 
                        //重組數(shù)組內(nèi)的樣式字符串
                        newCss += prevStr + "" + nextStr
                    } else {
                        //追加最后一個(gè)數(shù)組元素
                        newCss += newCssArr[i]
                    }
                }
                document.getElementById("newCss").innerHTML = newCss
            }
            $("#bbb").keydown(function(event) {
                if(event.which == 13) {
                    console.log("ok")
                }
            });
        </script>
    </body>
 
</html>
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容