詳解react內(nèi)聯(lián)樣式使用webpack將px轉(zhuǎn)rem
背景
在開發(fā)react項目時,很多時候我們把style寫在css、less、scss里,經(jīng)過像postcss這樣的配置處理,但有沒有這樣一種需求呢,像有些樣式我們直接寫在xml標(biāo)簽上style里,然后也能進(jìn)行處理,如px2rem能將px轉(zhuǎn)rem,是否在style上寫也能實(shí)現(xiàn)。
思路
我們在webpack,/.(js|jsx)?$/這樣babel-loader之前(webpack從右往左)加一個loader把需要轉(zhuǎn)變的px進(jìn)行替換,不就好了,先找找有沒有這樣的loader,我找了下沒找到,只能自己寫一個了
代碼
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;
}
};
用法
{
loader: path.join(rootPath, 'loaders/jsxPx2RemLoader'),
options: {
remUnit: 100,
remFixed: 3
}
}
源代碼
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
React循環(huán)遍歷渲染數(shù)組和對象元素方式
這篇文章主要介紹了React循環(huán)遍歷渲染數(shù)組和對象元素方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-09-09
react 下拉框內(nèi)容回顯的實(shí)現(xiàn)思路
這篇文章主要介紹了react 下拉框內(nèi)容回顯,實(shí)現(xiàn)思路是通過將下拉框選項的value和label一起存儲到state中, 初始化表單數(shù)據(jù)時將faqType對應(yīng)的label查找出來并設(shè)置到Form.Item中,最后修改useEffect,需要的朋友可以參考下2024-05-05
webpack手動配置React開發(fā)環(huán)境的步驟
本篇文章主要介紹了webpack手動配置React開發(fā)環(huán)境的步驟,webpack手動配置一個獨(dú)立的React開發(fā)環(huán)境, 開發(fā)環(huán)境完成后, 支持自動構(gòu)建, 自動刷新, sass語法 等功能...感興趣的小伙伴們可以參考一下2018-07-07
插件化機(jī)制優(yōu)雅封裝你的hook請求使用方式
這篇文章主要為大家介紹了插件化機(jī)制優(yōu)雅封裝你的hook請求使用方式示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07
react實(shí)現(xiàn)移動端下拉菜單的示例代碼
這篇文章主要介紹了react實(shí)現(xiàn)移動端下拉菜單的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-01-01

