在webpack自定义配置antd的按需加载和修改主题色

Posted 骑着小毛驴过冬的八阿哥

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了在webpack自定义配置antd的按需加载和修改主题色相关的知识,希望对你有一定的参考价值。

最近使用antd来做react项目的UI。从antd官网上,在使用create-react-app脚手架搭建项目时步骤如下:

(1)添加模块 react-app-rewired, babel-plugin-import, react-app-rewire-less

(2)根目录添加config-overrides.js

(3)修改npm script即可, 一切正常

参考官网

 

这里主要说的是自建的react项目中如何配置及其容易出现的坑

一、按需加载

  (1)在.babelrc中添加plugins (这里也可以在babel-loader的options中添加)

1 [‘import‘, { 
2     libraryName: ‘antd‘, 
3     libraryDirectory: ‘es‘,
4     style: ‘css‘ 
5     }
6 ]

  注意该步很容易有报错:

.bezierEasingMixin();Inline javascript is not enabled. Is it set in your options?
此时检查package.json中看看less的版本是否是3.x, 如果时降为[email protected]
再重启项目,搞定。

 

二、修改主题色

找到webpack.config.js的less-loader, 在options中添加

 1 {
 2      loader: ‘less-loader‘,
 3      options: {
 4         sourceMap: true,
 5         modifyVars: {
 6            ‘primary-color‘: ‘#1DA57A‘,
 7            ‘link-color‘: ‘#1DA57A‘,
 8            ‘border-radius-base‘: ‘2px‘
 9          },
10      javascriptEnabled: true   // 此项不能忘
11   }
12 }

此处有个坑,之前使用ExtractTextPlugin插件对css样式提取,但如配置主题色修改,不能再使用提取插件,另外,找到.babelrc中找到之前按需加载的配置修改:

1 [‘import‘, { 
2      libraryName: ‘antd‘, 
3      style:  true
4      }
5 ]

删除之前的 libraryDirectory: ‘es‘,

修改之前的 style: "css" 为 style: true

修改主题是基于less提供的modifyVars变量进行修改的,所以按需加载时使用true

主题定制


以上是关于在webpack自定义配置antd的按需加载和修改主题色的主要内容,如果未能解决你的问题,请参考以下文章

webpack antd 按需加载

react中执行yarn eject配置antd-mobile的按需加载

react18——使用craco库增量修改webpack——配置antd实现按需加载

react18——使用craco库增量修改webpack——配置antd实现按需加载

React UI组件库——如何快速实现antd的按需引入和自定义主题

React引入AntD按需加载报错