react內聯樣式使用webpack將px轉rem

背景

在開發react項目時,不少時候咱們把style寫在css、less、scss裏,通過像postcss這樣的配置處理,但有沒有這樣一種需求呢,像有些樣式咱們直接寫在xml標籤上style裏,而後也能進行處理,如px2rem能將px轉rem,是否在style上寫也能實現。javascript

思路

咱們在webpack,/.(js|jsx)?$/這樣babel-loader以前(webpack從右往左)加一個loader把須要轉變的px進行替換,不就行了,先找找有沒有這樣的loader,我找了下沒找到,只能本身寫一個了css

代碼

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
    }
}
複製代碼

源代碼

源碼java

讚揚

若是你以爲我寫的對你有幫助,請給我點贊助,不勝感激react

WechatIMG42.jpg
WechatIMG43.jpg
相關文章
相關標籤/搜索