React项目使用craco修改webpack配置

React项目使用craco

通过Create React App(CRA)搭建的react项目,webpack的相关配置是被默认隐藏起来的,如果想修改关于webpack的相关配置,有两种方式:

  • npm run eject
  • craco
npm run eject

npm run eject,会将原本creat react app对webpack,babel等相关配置的封装弹射出来,如果我们要将creat react app配置文件进行修改,现有目录下是没有地方修改的,此时,我们就可以通过eject命令将原本被封装到脚手架当中的命令弹射出来,然后就可以在项目的目录下看到很多配置文件。但这个操作是不可逆的,我们无法再通过其他方式将这些暴露出来的配置还原回去。

craco

通过 craco,开发者可以在不弹出 CRA 的配置的情况下,可以使用自定义的 webpack 插件、babel 插件和其他工具,以满足项目的特定需求。例如,可以添加自定义的 webpack loader,配置自定义的 babel preset 或 plugin,或者修改 webpack 的输出路径等。

安装carco
复制代码
npm install @craco/craco
npm install craco-less
在项目的根目录创建craco.config.js
复制代码
const CracoLessPlagin = require('craco-less')
const path = require('path')
const resolve = (dir) => path.resolve(__dirname, dir)
module.exports = {
    plugins: [{ plugin: CracoLessPlagin }],
    // 修改 webpack 配置
    webpack: {
        alias: {
            '@': resolve('src'),
            comp: resolve('src/components')
        }
      
    },
    // 修改 babel 配置
    babel: {
        // ...
    },
    // 修改 eslint 配置
    eslint: {
        // ...
    },
    devServer: {
        proxy: {

        }
    }
};
修改 package.json 文件
复制代码
 "scripts": {
    "start": "craco start",
    "build": "craco build",
    "test": "craco test",
    "eject": "react-scripts eject"
  }
修改tsconfig.json

添加

复制代码
"paths": {
    "@/*": ["./src/*"]
 }
在项目中可以使用 @ 代替 ./src 导入文件

import '@/App.css';

可能遇到的问题

报错:

"@babel/plugin-proposal-private-property-in-object" package without

declaring it in its dependencies. This is currently working because

"@babel/plugin-proposal-private-property-in-object" is already in your

node_modules folder for unrelated reasons, but it may break at any time.

解决办法:
npm install --save-dev @babel/plugin-proposal-private-property-in-object

相关推荐
CoolerWu32 分钟前
TRAE SOLO实战成功展示&总结:一个所见即所得的笔记软体
前端·javascript
Cassie燁39 分钟前
el-button源码解读1——为什么组件最外层套的是Vue内置组件Component
前端·vue.js
vx_bscxy32239 分钟前
告别毕设焦虑!Python 爬虫 + Java 系统 + 数据大屏,含详细开发文档 基于web的图书管理系统74010 (上万套实战教程,赠送源码)
java·前端·课程设计
北极糊的狐40 分钟前
Vue3 子组件修改父组件传递的对象并同步的方法汇总
前端·javascript·vue.js
spionbo40 分钟前
Vue3 前端分页功能实现的技术方案及应用实例解析
前端
AI绘画小3342 分钟前
Web 安全核心真相:别太相信任何人!40 个漏洞挖掘实战清单,直接套用!
前端·数据库·测试工具·安全·web安全·网络安全·黑客
7***n7544 分钟前
前端设计模式详解
前端·设计模式·状态模式
用户47949283569151 小时前
Vite 中 SVG 404 的幕后黑手:你真的懂静态资源处理吗?
前端·vite
未来之窗软件服务1 小时前
幽冥大陆(三十五)S18酒店门锁SDK go语言——东方仙盟筑基期
java·前端·golang·智能门锁·仙盟创梦ide·东方仙盟·东方仙盟sdk
卸任1 小时前
解密Flex布局:为什么flex:1仍会导致内容溢出
前端·css·flexbox