亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

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

發布時間:2020-09-25 12:34:44 來源:腳本之家 閱讀:528 作者:sunshinng 欄目:web開發

背景

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

源代碼

源碼

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

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

新营市| 玉溪市| 昂仁县| 泸州市| 武定县| 达日县| 广州市| 安阳市| 永新县| 台东市| 宁陵县| 洮南市| 锦州市| 柞水县| 铁岭市| 渑池县| 康乐县| 盖州市| 定南县| 基隆市| 永清县| 漳平市| 永春县| 荆门市| 信宜市| 宾阳县| 年辖:市辖区| 邵东县| 定安县| 会泽县| 红原县| 大邑县| 奉化市| 新闻| 府谷县| 内江市| 定远县| 庄浪县| 泰宁县| 楚雄市| 阿荣旗|