背景
在開發(fā)react項(xiàng)目時(shí),很多時(shí)候我們把style寫在css、less、scss里,經(jīng)過像postcss這樣的配置處理,但有沒有這樣一種需求呢,像有些樣式我們直接寫在xml標(biāo)簽上style里,然后也能進(jìn)行處理,如px2rem能將px轉(zhuǎn)rem,是否在style上寫也能實(shí)現(xiàn)。
思路
我們?cè)趙ebpack,/.(js|jsx)?$/這樣babel-loader之前(webpack從右往左)加一個(gè)loader把需要轉(zhuǎn)變的px進(jìn)行替換,不就好了,先找找有沒有這樣的loader,我找了下沒找到,只能自己寫一個(gè)了
代碼
const loaderUtils = require('loader-utils'); // 默認(rèn)參數(shù) const defaultopts = { remUnit: 100, // rem unit value (default: 100) remFixed: 2, // rem value precision (default: 2) }; // 獲取webpack配置好的參數(shù) const opts = loaderUtils.getOptions(this); // 將參數(shù)組合 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下有沒有符合的如果有再進(jìn)行替換 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; } };