【react进阶】create-react-app高阶配置

create-react-app新建项目还是官网推荐的主流方法,当然vite已经使用越来越广泛了,构建速度也是比cra快几倍。记录下怎么用cra来搭建一个react项目。

在index.html文件中使用变量

1.在script代码中的使用方式

html 复制代码
<script>
       const $ = window.$ = "anc"
       window.SITE_CONFIG = {}
       if ('<%= process.env.NODE_ENV %>' === 'development') {
        window.SITE_CONFIG['apiURL'] = '/api';  
      }
      else {
        window.SITE_CONFIG['apiURL'] = '/prod_api';         
      }
    </script>
  1. 在html标签中使用方式,随便引入一个库
html 复制代码
<% if (process.env.NODE_ENV === 'development') { %>
 <script src="%PUBLIC_URL%/libs/vue/vue.js"></script>
  <% } else { %>
  <script src="%PUBLIC_URL%/libs/vue/vue.min.js"></script>
  <% }
%>

3.dev环境效果

全局变量已经成功注入


4.生产环境效果



覆盖wbepack默认样式

不要轻易弹出create-react-app的配置,这个操作是不可逆的,我们使用官网推荐的方式进行自定义webpack配置

  • 安装依赖
bash 复制代码
 "devDependencies": {
    "@craco/craco": "^7.1.0"
  }
  • 修改配置文件,这里要参考craco和webpack的官网,进行对应详细的options配置
  • 在项目根目录下面新建一个craco.config.js的配置文件
js 复制代码
/* craco.config.js */
const path = require("path");
module.exports = {
  webpack: {
    alias: {
      "@": path.resolve(__dirname, "src"),   // 资源引入的绝对路径配置
    },
  },
  devServer: {
    port: 9090,
    client: {
      logging: "info",
      overlay: false,
      progress: true,
    },
    headers: {
      "X-Custom-Foo": "bar",
    },
  },
  style: {
    sass: {
      loaderOptions: (sassOptions) => {
        sassOptions.additionalData = `@import "@/assets/styles/_variables.scss";`;  // 全局的sass变量文件配置
        return sassOptions;
      },
    },
  },
};
相关推荐
北京_宏哥1 分钟前
🔥Jmeter(五) - 从入门到精通 - 创建网络计划实战和创建高级Web测试计划(详解教程)
前端·jmeter·面试
百锦再7 分钟前
Reactive编程框架与工具
前端·javascript·python·django·vue·框架·react
江城开朗的豌豆7 分钟前
CSS篇:移动端适配必学:750设计图的px到rem精准换算方法
前端·css·面试
掉毛的小羊羔21 分钟前
🛸理解 MCP:工作原理、技术架构与 AI Agent 的关系全解析
前端·后端·架构
写bug写bug23 分钟前
掌握 HTTP 状态码
前端·后端·http
周星星日记25 分钟前
09.vue3中watch实现思路
前端·vue.js
不乖的肥猫27 分钟前
第十二步:react
前端·react.js·前端框架
就是我28 分钟前
JavaScript这几种内存泄露写法,你要小心了
前端·javascript·代码规范
日升30 分钟前
时区转换工具+PWA离线网页
前端·javascript
import_random30 分钟前
[机器学习]bagging, boosting, stacking
前端·机器学习