首页 > 编程 > JavaScript > 正文

详解react内联样式使用webpack将px转rem

2019-11-19 12:56:57
字体:
来源:转载
供稿:网友

背景

在开发react项目时,很多时候我们把style写在css、less、scss里,经过像postcss这样的配置处理,但有没有这样一种需求呢,像有些样式我们直接写在xml标签上style里,然后也能进行处理,如px2rem能将px转rem,是否在style上写也能实现。

思路

我们在webpack,/.(js|jsx)?$/这样babel-loader之前(webpack从右往左)加一个loader把需要转变的px进行替换,不就好了,先找找有没有这样的loader,我找了下没找到,只能自己写一个了

代码

const loaderUtils = require('loader-utils');// 默认参数const defaultopts = {  remUnit: 100, // rem unit value (default: 100)  remFixed: 2, // rem value precision (default: 2)};// 获取webpack配置好的参数const opts = loaderUtils.getOptions(this);// 将参数组合const config = Object.assign({}, defaultopts, opts);const ZPXRegExp = //b(/d+(/./d+)?)SUPX/b/;module.exports = function (source) {  let pxGlobalRegExp = new RegExp(ZPXRegExp.source, 'g');  if (this.cacheable) {    this.cacheable();  }  // 先test下有没有符合的如果有再进行替换  if (pxGlobalRegExp.test(source)) {    return source.replace(pxGlobalRegExp, ($0, $1) => {      let val = $1 / config.remUnit;      // 精确到几位      val = parseFloat(val.toFixed(config.remFixed));      return val === 0 ? val : val + 'rem';    });  } else {    return source;  }};

用法

{  loader: path.join(rootPath, 'loaders/jsxPx2RemLoader'),  options: {    remUnit: 100,    remFixed: 3  }}

源代码

源码

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持武林网。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表