關於最新create-react-app使用react-app-rewired2.x添加webpack配置


使用過create-react-app(以下簡稱cra)的朋友都知道,這是react官方的一款腳手架工具,內部集成了babel,webpack,webpack-dev-server等等。

以前我們要在cra中做webpack的配置,有三種方式:

1、運行npm run eject得到原始的webpack配置文件config,然后可以看到里面有prod和dev兩個環境的相關配置;但是新版本cra你run eject之后,只有一個webpack.config.js文件了。

可以在這里面進行配置。但是本文中這不是我們推薦的方式。

2、不run eject。而是改寫script文件中的js。這個本人沒有操作過,這個就不詳談了。

3、使用react-app-rewired,安裝這個工具后,在項目根目錄中新建文件config-overrides.js文件。此時我們便可以在其中進行各種webpack的騷操作了~

但是!react-app-rewired2.x以后,不再支持injectBabelPlugin的方式,需要安裝customize-cra

具體的,ant design官方文檔已經給出了最新的解決方案。請前往詳覽。https://ant.design/docs/react/use-with-create-react-app-cn

這種方式就是我們推薦的方式。因為無需生成更多額外的文件,同時配置又趨於更簡單可控的方式。

接下來我們就來具體說一下操作步驟。

首先,我們安裝react-app-rewired。

$ yarn add react-app-rewired

然后修改package.json文件如下,

/* package.json */
"scripts": {
-   "start": "react-scripts start",
+   "start": "react-app-rewired start",
-   "build": "react-scripts build",
+   "build": "react-app-rewired build",
-   "test": "react-scripts test",
+   "test": "react-app-rewired test",
}

接着,安裝customize-cra

$ yarn add customize-cra

然后在根目錄下添加config-overrides.js文件。

module.exports = function override(config, env) {
  // 關於webpack的相關配置
  return config;
};

好了,基本的操作就是這樣。下面我們再來說具體到我們的項目中,需要做的一些配置。

1、react項目中我們最常用的組件庫antd,我們需要配置按需加載。

使用babel-plugin-import,它是一個用於按需加載組件代碼和樣式的 babel 插件。

安裝

$ yarn add babel-plugin-import

接着配置webpack 

/* config-overrides.js */
+ const { override, fixBabelImports } = require('customize-cra');

- module.exports = function override(config, env) {
-   return config;
- };
+ module.exports = override(
+   fixBabelImports('import', {
+     libraryName: 'antd',
+     libraryDirectory: 'es',
+     style: 'css',
+   }),
+ );

這樣我們在組件中就可以按需引入組件庫中所需要的組件了。

2、自定義主題

按照配置主題的要求,自定義主題需要用到 less 變量覆蓋功能。

安裝less和less-loader

$ yarn add less less-loader

配置webpack

/* config-overrides.js */
- const { override, fixBabelImports } = require('customize-cra');
+ const { override, fixBabelImports, addLessLoader } = require('customize-cra');

module.exports = override(
  fixBabelImports('import', {
    libraryName: 'antd',
    libraryDirectory: 'es',
-   style: 'css',
+   style: true,
  }),
+ addLessLoader({
+   javascriptEnabled: true,
+   modifyVars: { '@primary-color': '#1DA57A' },
+ }),
);

這里利用了less-loader的modifyVars來進行主題配置。當然這里的modifyVars的值也可以是一個theme文件。

3、打包后我們會發現靜態文件夾中會有很多的css和js的map文件,那么我們該怎么關閉sourcemap呢?

/* config-overrides.js */
const { override, fixBabelImports, addLessLoader } = require("customize-cra");

+ process.env.GENERATE_SOURCEMAP = "false";

module.exports = override(
  fixBabelImports("import", {
    libraryName: 'antd',
    libraryDirectory: "es",
    style: true,
  }),
  addLessLoader({
    javascriptEnabled: true,
    modifyVars: { '@primary-color': '#1DA57A' },
  })
);

ok,再次執行npm run build便不會產生map文件了。

還看到一種解決的方式如下,

const rewiredMap = () => config => {
    config.devtool = config.mode === 'development' ? 'cheap-module-source-map' : false;
    return config;
};

module.exports = override(
    // 關閉mapSource
    rewiredMap()
);

參考地址:https://segmentfault.com/q/1010000018123194

4、支持裝飾器

const { override, addDecoratorsLegacy } = require("customize-cra");
module.exports = override(
    addDecoratorsLegacy()
);

5、最后我們來說說前端本地proxy的配置

開發中常見的問題就是跨域。那么我們前端慣用的方式就是給本地webpack啟動的node服務設置代理。

那么具體到使用了新版的cra后,我們該怎么辦呢?

很簡單,在src目錄下新建文件setupProxy.js(注意文件名一定要是這個名字,不要問什么,cra現在廢棄了proxy對象配置的方式,將其作為單獨模塊。解析就是按 src/setupProxy.js這個路徑

安裝http代理相關包http-proxy-middleware

$ yarn add http-proxy-middleware -D

配置如下,

const proxy = require('http-proxy-middleware')

module.exports = function(app) {
  app.use(
    proxy('/api', {
      target: 'http://xx.xx.xx.xx:8000/',
      changeOrigin: true,
      pathRewrite: {
        '^/api': ''
      }
    })
  )
}

好了,現在你就可以愉快的訪問接口了~

關於更多的customize-cra配置,大家可以自行查看文檔。https://github.com/arackaf/customize-cra

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM