您好,登錄后才能下訂單哦!
背景
在開發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 } }
源代碼
源碼
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。