国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > JavaScript > 正文

詳解react內(nèi)聯(lián)樣式使用webpack將px轉(zhuǎn)rem

2019-11-19 12:56:57
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

背景

在開發(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;  }};

用法

{  loader: path.join(rootPath, 'loaders/jsxPx2RemLoader'),  options: {    remUnit: 100,    remFixed: 3  }}

源代碼

源碼

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持武林網(wǎng)。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 油尖旺区| 五大连池市| 黄浦区| 九台市| 论坛| 中山市| 澄江县| 凤庆县| 措美县| 通辽市| 疏附县| 河北区| 渭南市| 开封市| 乌拉特中旗| 长乐市| 厦门市| 宝兴县| 白玉县| 梅河口市| 岑溪市| 民乐县| 阿拉善盟| 桂阳县| 从化市| 四会市| 福贡县| 田东县| 龙山县| 祁阳县| 宝山区| 伽师县| 建阳市| 卢龙县| 平昌县| 吉木萨尔县| 砚山县| 乃东县| 泸溪县| 许昌县| 海南省|