React craco 详细使用与介绍(类似 Vue 外抛的 vue.config.js)

简介: React craco 详细使用与介绍(类似 Vue 外抛的 vue.config.js)

一、简介

  • craco 官方文档craco Github
  • craco 是一个用于扩展 Create React App(CRA)的工具,CRA 是一个用于快速搭建 React 应用的脚手架工具。CRA 提供了一个简单的项目结构和配置,使得开发者可以快速开始一个 React 项目的开发。
    然而 CRA 的配置是被隐藏的,开发者无法对其进行自定义和扩展。这就是 craco 出现的原因。craco(Create React App Configuration Override) 允许开发者覆盖和扩展 CRA 的配置,以满足更复杂的项目需求。
    使用 craco,开发者可以在不弹出 CRA 的配置的情况下,修改 webpack 配置babel 配置ESLint 配置devServer配置 等。craco 提供了一种简单的方式来覆盖 CRA 的默认配置,同时保留了 CRA 的简洁性和易用性。
    通过 craco,开发者可以使用自定义的 webpack 插件babel 插件其他工具,以满足项目的特定需求。例如:可以添加自定义的 webpack loader,配置自定义的 babel presetplugin,或者修改 webpack 的输出路径等。

二、使用

  • 安装
$ npm i -D @craco/craco
  • 根目录创建 craco.config.js 配置文件,可以理解为 Vue 项目中外抛的 vue.config.js
my-app  
    ├── node_modules  
  + ├── craco.config.js  
    └── package.json
  • 配置文件名其他写法支持,如果找到多个配置文件,craco 将使用上面列表中最高的一个:
1、craco.config.ts
2、craco.config.js
3、craco.config.cjs
4、.cracorc.ts
5、.cracorc.js
6、.cracorc
  • 如果多个配置文件,也可以通过 package.json 添加字段指定配置文件:
...
{  
    "cracoConfig": "config/craco-config-with-custom-name.js"  
}
...
  • scripts 指令中指定配置文件进行编译:
{  
    "scripts": {  
        "start": "craco start --config config/craco-config-with-custom-name.js"  
    }  
}
  • 修改 package.json 文件中 scripts 配置的 react-scripts 替换为 craco,例如:
"scripts": {
-   // "start": "react-scripts start",
-   // "build": "react-scripts build",
-   // "test": "react-scripts test",
+   "start": "craco start",
+   "build": "craco build",
+   "test": "craco test",
    "eject": "react-scripts eject"
}
  • craco.config.js 文件中,可以根据需要修改和扩展 CRA 的配置。以下是一个示例配置文件的基本结构:
    基本可以覆盖正常业务的所有需求配置,更多配置可以查看下 官方文档
const path = require('path')
const lessPlugin = require('craco-less')
module.exports = {
  // 插件配置
  plugins: [
    {
      plugin: lessPlugin,
      options: {
        lessLoaderOptions: {
          lessOptions: {
            // modifyVars: { '@primary-color': '#1DA57A' },
            javascriptEnabled: true
          }
        }
      }
    }
    // ...
  ],
  // 修改 babel 配置
  babel: {
    // plugins: [
    //   ['@babel/plugin-proposal-decorators', { legacy: true }],
    //   [   
    //     'import', 
    //     {
    //       'libraryName': 'antd',
    //       'libraryDirectory': 'es',
    //       'style': 'css' // 设置为 true 即是 less 这里用的是 css
    //     }
    //   ]
    // ]
    // ...
  },
  // 修改 eslint 配置
  eslint: {
    // ...
  },
  // 修改 module 配置
  module: {
    // rules:[// 规则,在写 style.module.scss 的时候发现引入后缀为 .scss 会报错,在这里配置一下即可
    //   {
    //     test: /.scss$/,
    //     loaders: ['style-loader', 'css-loader', 'sass-loader']
    //   }
    // ]
    // ...
  },
  // 跨域配置
  devServer: {
    proxy: {
      '/api': {
        target: 'https://xxx:8080',
        changeOrigin: true,
        pathRewrite: {
          '^/api': ''
        }
      }
    }
    // ...
  },
  // webpack 配置
  webpack: {
    // 配置别名
    alias: {
      // 约定:使用 @ 表示 src 文件所在路径
      '@': path.resolve(__dirname, 'src')
    },
    // webpack 插件
    plugins: {
      add: [ /* ... */],
      remove: [ /* ... */],
    },
    // plugins: [
    //   new ConfigWebpackPlugin(),
    //   ...whenDev(() => [new CircularDependencyPlugin()], []),
    // ],
    // 这里面是 webpack 原始配置,这里追加的配置,将与原始配置合并
    configure: {
      resolve: {
        fallback: {
          'path': false,
          'util': false,
          'url': false,
          'http': false,
          'https': false,
          'stream': false,
          'assert': false,
          'querystring': false,
          'zlib': false
        }
      }
    }
    // ...
  }
}
相关文章
|
8月前
|
编解码 前端开发 JavaScript
js react antd 实现页面低分变率和高分变率下字体大小自适用,主要是配置antd
在React中结合Ant Design与媒体查询,通过less变量和响应式断点动态调整`@font-size-base`,实现多分辨率下字体自适应,提升跨设备体验。
407 2
|
移动开发 前端开发 JavaScript
Vue与React两大前端框架的主要差异点
以上就是Vue和React的主要差异点,希望对你有所帮助。在选择使用哪一个框架时,需要根据项目的具体需求和团队的技术栈来决定。
675 83
|
10月前
|
JavaScript 前端开发 API
对比Vue框架与React库的主要区别
在选择Vue还是React时,考虑项目的需求、团队的熟悉程度和个人偏好至关重要。如果项目需要快速原型开发和较小的学习曲线,Vue可能是更好的选择。相反,如果项目需要更大的灵活性,或者项目团队已经有React的经验,那么React可能是更合适的选择。
446 13
|
存储 缓存 JavaScript
如何优化React或Vue应用的性能
需要注意的是,性能优化是一个持续的过程,需要根据具体的应用场景和性能问题进行针对性的优化。同时,不同的项目和团队可能有不同的优化重点和方法,要结合实际情况灵活运用这些优化策略,以达到最佳的性能效果。
755 158
|
前端开发 JavaScript NoSQL
使用 Node.js、Express 和 React 构建强大的 API
本文详细介绍如何使用 Node.js、Express 和 React 构建强大且动态的 API。从开发环境搭建到集成 React 前端,再到利用 APIPost 高效测试 API,适合各水平开发者。内容涵盖 Node.js 运行时、Express 框架与 React 库的基础知识及协同工作方式,还涉及数据库连接和前后端数据交互。通过实际代码示例,助你快速上手并优化应用性能。
|
数据采集 JavaScript Android开发
【02】仿站技术之python技术,看完学会再也不用去购买收费工具了-本次找了小影-感觉页面很好看-本次是爬取vue需要用到Puppeteer库用node.js扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-优雅草卓伊凡
【02】仿站技术之python技术,看完学会再也不用去购买收费工具了-本次找了小影-感觉页面很好看-本次是爬取vue需要用到Puppeteer库用node.js扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-优雅草卓伊凡
646 7
【02】仿站技术之python技术,看完学会再也不用去购买收费工具了-本次找了小影-感觉页面很好看-本次是爬取vue需要用到Puppeteer库用node.js扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-优雅草卓伊凡
|
JavaScript 前端开发 算法
vue和react 哪个更强大
vue和react 哪个更强大
372 3