create-react-app利用craco配置路径别名、Less

写的挺好,直接搬过来了,验证过,不是无脑搬运
原文 &  参考

 

1.安装 craco/craco

$ yarn add  @craco/craco
# OR
$ npm install @craco/craco --save

 

2.修改 package.json 文件

"scripts": {
//   "start": "react-scripts start",
//   "build": "react-scripts build",
//   "test": "react-scripts test",
  "start": "craco start",
  "build": "craco build",
  "test": "craco test",
}

 

3. 在根目录下创建craco.config.js文件用于修改默认配置

craco.config.js 和 package.json同级

my-app
├── node_modules
├── craco.config.js
└── package.json


module.exports = {
  // 配置文件
}

 

一、配置别名

配置别名也需要修改webpack的配置,当然我们也可以借助于 craco 来完成:

...

const path = require("path");
const resolve = dir => path.resolve(__dirname, dir);

module.exports = {
  ...
  ,
  webpack: {
    alias: {
      '@': resolve("src"),
      'components': resolve("src/components"),
    }
  }
}

 

在导入时就可以按照下面的方式来使用了:

import CommentInput from '@/components/comment-input';
import CommentItem from 'components/comment-item';

 

二、在create-react-app中使用Less

1.安装 craco-less ( 内部自动安装 less less-loader 相关依赖 )

npm install craco-less --save

 

2.配置 craco.config.js 文件

const CracoLessPlugin = require("craco-less");
 
module.exports = {
  plugins: [{ plugin: CracoLessPlugin }]
};

 

如何适配css Modules

const CracoLessPlugin = require("craco-less");

module.exports = {
    plugins: [
        {
          plugin: CracoLessPlugin,
          options: {
            cssLoaderOptions: {
              modules: { localIdentName: "[local]_[hash:base64:5]" },
            }
          }
        }
    ]
};

 

posted @ 2021-07-21 19:53  丁少华  阅读(2204)  评论(2编辑  收藏  举报