【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;
      },
    },
  },
};
相关推荐
神奇的程序员31 分钟前
开发了一个管理本地开发环境的软件
前端·flutter
XiYang-DING1 小时前
HTML 核心标签
前端·html
Csvn1 小时前
技术选型方法论
前端
Csvn2 小时前
前端架构演进:从页面到平台的十年变革
前端
李伟_Li慢慢2 小时前
ShaderToy-山峦+蓝天+白云
前端·webgl
小码哥_常2 小时前
Android字体字重设置全攻略:XML黑科技+Kotlin动态实现,告别.ttf臃肿
前端
言萧凡_CookieBoty3 小时前
AI 编程省 Token 实战:从 Spec、上下文工程到模型分层的降本策略
前端·ai编程
DFT计算杂谈4 小时前
wannier90 参数详解大全
java·前端·css·html·css3
铁皮饭盒5 小时前
第2课:5分钟!用 Trae AI 生成你的第一个后端服务(Bunjs + Elysia)
前端·后端·全栈