【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;
      },
    },
  },
};
相关推荐
程序员Agions7 分钟前
useMemo、useCallback、React.memo,可能真的要删了
前端·react.js
滕青山9 分钟前
Vue项目BMI计算器技术实现
前端·vue.js
子兮曰14 分钟前
深入浏览器指纹:Canvas、WebGL、Audio是如何暴露你的身份的?
前端·浏览器·canvas
月亮补丁15 分钟前
AntiGravity只能生成 1:1 图片?一招破解尺寸限制
前端
何中应20 分钟前
MindMap部署
前端·node.js
NAGNIP23 分钟前
程序员效率翻倍的快捷键大全!
前端·后端·程序员
一个网络学徒26 分钟前
python5
java·服务器·前端
tiantian_cool27 分钟前
Claude Opus 4.6 模型新特性(2026年2月5日发布)
前端
0思必得031 分钟前
[Web自动化] Selenium获取元素的子元素
前端·爬虫·selenium·自动化·web自动化
用户57573033462438 分钟前
🌟 从一行 HTML 到屏幕像素:浏览器是如何“画”出网页的?
前端