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

首頁 > 開發 > JS > 正文

詳解react內聯樣式使用webpack將px轉rem

2024-05-06 16:46:05
字體:
來源:轉載
供稿:網友

px; padding: 5px 0px; outline: none; font-size: 14px; line-height: 30px; font-family: tahoma, arial, "Microsoft YaHei";"> 背景

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

源代碼 

源碼

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 武安市| 莱芜市| 泸溪县| 高邮市| 当阳市| 松桃| 凌云县| 乌拉特后旗| 华容县| 专栏| 当涂县| 浦东新区| 隆安县| 黄石市| 美姑县| 克什克腾旗| 凤冈县| 南木林县| 高阳县| 新干县| 安康市| 淳安县| 酒泉市| 贡山| 万宁市| 普兰县| 虎林市| 兴安盟| 磐石市| 张家口市| 雅江县| 黑河市| 老河口市| 鹤壁市| 黔西县| 婺源县| 常宁市| 晋城| 宣化县| 巩留县| 勃利县|