react eject后antd如何定制主题
官网只介绍了没有eject的方法,用craco来配置,但是eject后,script脚本就变了craco再改脚本就不行了, 官网地址: 所以探索了一下如何自定义主题 、,重点是参考2
需要配置less,yarn add less less-loader -D 然后在webpack.config.js里面添加如下
const lessRegex = /.(css|less)$/; const lessModuleRegex = /.module.(css|less)$/
后面加这个
// less
            {
          
   
              test: lessRegex,
              exclude: lessModuleRegex,
              use: getStyleLoaders(
                {
          
   
                  importLoaders: 3,
                  sourceMap: isEnvProduction
                    ? shouldUseSourceMap
                    : isEnvDevelopment,
                  modules: {
          
   
                    mode: icss
                  }
                },
                less-loader
              ),
              sideEffects: true
            },
            {
          
   
              test: lessModuleRegex,
              use: getStyleLoaders(
                {
          
   
                  importLoaders: 3,
                  sourceMap: isEnvProduction
                    ? shouldUseSourceMap
                    : isEnvDevelopment,
                  modules: {
          
   
                    mode: local,
                    getLocalIdent: getCSSModuleLocalIdent
                  }
                },
                less-loader
              )
            }, 
然后在getStyleLoaders函数中添加如下
if (preProcessor) {
          
   
      loaders.push(
        {
          
   
          loader: require.resolve(resolve-url-loader),
          options: {
          
   
            sourceMap: isEnvProduction ? shouldUseSourceMap : isEnvDevelopment,
            root: paths.appSrc
          }
        },
        {
          
   
          loader: require.resolve(preProcessor),
          options: {
          
   
            sourceMap: true,
            // 配置craco,因为eject暴露了之后就不能直接用craco.config.js
            lessOptions: preProcessor === less-loader ? {
          
   
              modifyVars: {
          
   //这里就是craco.config.js中的自定义主题内容了
                @primary-color: rgb(0,82,204),
                // 不加@符号也行
                // primary-color: rgb(0,82,204),
                @font-size-base: 16px
              },
              javascriptEnabled: true,
            } : null
          }
        }
      )
    } 
然后在package.json中添加
"babel": {
          
   
    "presets": [
      "react-app"
    ],
    "plugins": [
      [
        "import",
        {
          
   
          "libraryName": "antd",
          "libraryDirectory": "es",
          "style": "true"
        }
      ]
    ]
  } 
然后yarn add babel-plugin-import,然后在index.tsx中引入如下文件
import ../node_modules/antd/dist/antd.less // import antd/dist/antd.less
我配置了tsconfig的baseUrl,所以无法直接引入antd/dist/antd.less,就用了绝对路径
这个问题可以参考一下,不过我暂时没解决
上一篇:
			            通过多线程提高代码的执行效率例子 
			          
			          
			        