使用正则表达式将后端返回的富文本中的px转换为rem

在vue移动端中,使用pxtorem插件无法将行内样式中的px转换为rem,所以会出现排版错乱的问题,可以使用正则表达是对返回的格式进行处理之后再使用

返回的格式实例

代码

        function convertPxToRem(str) {
            // 获取屏幕宽度
            const screenWidth = window.screen.width;
            // 计算html的fontsize
            const htmlFontSize = (screenWidth / 375) * 16;
            // 匹配所有的px值
            const reg = /(\d+)px/g;
            // 将匹配到的px值转换成rem
            return str.replace(
              reg,
              ($0, $1) => `${parseFloat($1) / htmlFontSize}rem`
            );
          }
          const richText = res.data.data.content;

          const convertedText = convertPxToRem(richText);

          console.log(convertedText);

          // 示例
          this.contant = convertedText;

处理之后的富文本实例

可以发现px已经全部转换为rem了

在vue中可以使用v-html解析富文本

      <div v-html="contant"></div>

如果排版还是错乱,可以跟后端商量一下换一种方法,可以返回一个链接,然后前端只需在页面中内嵌这个网页即可

可以使用iframe标签内嵌网页

<iframe src="链接地址" frameborder="0" class="ifcontant"></iframe>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值