背景
十多年的西區(qū)網(wǎng)站建設(shè)經(jīng)驗(yàn),針對(duì)設(shè)計(jì)、前端、開發(fā)、售后、文案、推廣等六對(duì)一服務(wù),響應(yīng)快,48小時(shí)及時(shí)工作處理。全網(wǎng)整合營銷推廣的優(yōu)勢(shì)是能夠根據(jù)用戶設(shè)備顯示端的尺寸不同,自動(dòng)調(diào)整西區(qū)建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設(shè)計(jì),從而大程度地提升瀏覽體驗(yàn)。成都創(chuàng)新互聯(lián)從事“西區(qū)網(wǎng)站設(shè)計(jì)”,“西區(qū)網(wǎng)站推廣”以來,每個(gè)客戶項(xiàng)目都認(rèn)真落實(shí)執(zhí)行。在開發(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; } };