美文网首页
15.rem转rpx

15.rem转rpx

作者: 秀萝卜 | 来源:发表于2020-12-25 12:04 被阅读0次
<!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转换rpx" onclick="rem2rpx()" />
        <h4>转换后的样式</h4>
        <textarea id="newCss" cols="60" rows="10"></textarea>
        <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;}"
                //对原样式根据rem进行拆分成数组,这样除了最后一个元素,数组前边的几个元素都是以原rem样式数值结尾
                //拆分后的格式:[".similar_recommend{background:#fff;border-radius:.1", ";height:7.4", ";margin-top:-.3", "}"]
                oldCss = oldCss.replace(/div/g,"view")
                oldCss = oldCss.replace(/span/g,"text")
                var newCssArr = oldCss.split("rem")
                var newCss = "" //转换后新的样式变量
                for(var i in newCssArr) {
                    if(i < newCssArr.length - 1) {
                        //非最后一个元素,对字符串按照:再次拆分,把rem样式的数值分离出来进行转换
                        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 = "0." + nextStr
                            //nextStr格式为.3rem或3rem
                            // if(nextStr.indexOf('.') > -1) {
                            //     nextStr = "-0." + nextStr
                            // }
                            nextStr = "-" + accMul(nextStr,100) + "rpx"
                        } else {
                            nextStr = str.substring(idx + 1, str.length)
                            //处理 nextStr="1px .2"的情况
                            var index = nextStr.lastIndexOf(' ')
                            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 = accMul(str2,100) + "rpx"
                                nextStr = str1 + ' ' + str2
                            } else {
                                nextStr = nextStr.indexOf('.') > -1 ? "0" + nextStr : nextStr
                                nextStr = accMul(nextStr,100) + "rpx"
                            }
                        }

                        //重组数组内的样式字符串
                        newCss += prevStr + "" + nextStr
                    } else {
                        //追加最后一个数组元素
                        newCss += newCssArr[i]
                    }
                }
                newCss = newCss.replace(/div/g,"view")
                newCss = newCss.replace(/\.\.\/img\//g,"../../img/")
                newCss = newCss.replace(/span/g,"text")
                newCss = newCss.replace(/>img/g,">image")
                document.getElementById("newCss").innerHTML = newCss
            }


            function accMul(arg1,arg2)
            {
              var m=0,s1=arg1.toString(),s2=arg2.toString();
              try{m+=s1.split(".")[1].length}catch(e){};
              try{m+=s2.split(".")[1].length}catch(e){};
              var z = Number(s1.replace(".",""))*Number(s2.replace(".",""))/Math.pow(10,m);
              return z;
              // return z.toFixed(2);
            }


            // $("#bbb").keydown(function(event) {
            //     if(event.which == 13) {
            //         console.log("ok")
            //     }
            // });
        </script>
    </body>

</html>

相关文章

  • 15.rem转rpx

  • rpx转px

    小程序 wxss 中使用 rpx,而 js 中 获取到的值是 px,所以存在rpx 转 px 的问题。以 iPho...

  • 阴影

    box-shadow: 0rpx 0rpx 5rpx 5rpx #dddddd;

  • uniapp px转rpx适配

    最近做了个小程序的项目之前用的是mpvue,做到一半发现挺多坑的,然后官方也不维护了。就想着换到uniapp。花几...

  • rem转rpx前端代码

    效果 代码:

  • 【uni-app】不同尺寸设计稿,尺寸自动转换

    HBuilderX - 偏好设置 - 编辑器配置 - px转rpx/upx比例 750设计稿 - 比例750/75...

  • 微信原生小程序rpx和生命周期

    rpx rpx(responsive pixel): 可以根据屏幕宽度进行自适应。规定屏幕宽为750rpx。如在 ...

  • uniapp踩坑记

    首先我是用cli创建的项目 1.项目配置px转rpx 安装postcss-pxtorpx-pro vite.con...

  • 微信小程序笔记

    单位 rpx rpx类似于 Android 中dp,具有设备独立性,最大屏幕宽度为750rpx。 字体加粗 单位 ...

  • 小程序之WXSS

    WXSS和CSS区别有以下几个方面: 尺寸单位rpx 样式导入 内联样式 选择器 尺寸单位rpx rpx和rem相...

网友评论

      本文标题:15.rem转rpx

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