背景
在開發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 = /(d+(.d+)?)SUPX/;
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
}
}
複製程式碼
原始碼
讚賞
如果你覺得我寫的對你有幫助,請給我點贊助,不勝感激