如何在 CRA 弃用后创建 React 应用程序

如何在 cra 弃用后创建 react 应用程序

React团队弃用create-react-app (CRA)后,开发者们转向了Vite和Webpack等替代方案来构建React应用。本文将对比这两个工具,并提供各自的入门配置指南。

Vite vs. Webpack

Vite

优点: 超快的开发服务器,配备即时热模块替换 (HMR) 功能;内置支持现代JavaScript特性;配置简洁。缺点: 相对较新的工具,社区支持可能不如Webpack成熟。

Webpack

优点: 高度可配置且灵活,适用于复杂构建场景;拥有庞大的插件生态系统和强大的社区支持;经受了众多大型应用的考验。缺点: 初始配置较复杂,耗时较长;构建速度比Vite慢。

使用 Vite 创建 React 应用

创建新项目:

npm create vite@latest my-react-app -- --template reactcd my-react-appnpm install

启动开发服务器:

npm run dev

Vite 配置:

Vite 的默认配置通常足以满足大多数React项目的需求。如有必要,可通过 vite.config.js 进行自定义。

使用 Webpack 创建 React 应用

初始化项目:

mkdir my-react-appcd my-react-appnpm init -ynpm install react react-dom webpack webpack-cli webpack-dev-server html-webpack-plugin babel-loader @babel/core @babel/preset-env @babel/preset-react

创建项目结构:创建 src 文件夹,并在其中添加 index.jsApp.js 文件。创建 public 文件夹,并在其中添加 index.html 文件。配置 Webpack:

创建 webpack.config.js 文件:

const path = require('path');const HtmlWebpackPlugin = require('html-webpack-plugin');module.exports = {  entry: './src/index.js',  output: {    path: path.resolve(__dirname, 'dist'),    filename: 'bundle.js',  },  module: {    rules: [      {        test: /.(js|jsx)$/,        exclude: /node_modules/,        use: {          loader: 'babel-loader',        },      },      {        test: /.css$/,        use: ['style-loader', 'css-loader'],      },    ],  },  resolve: {    extensions: ['.js', '.jsx'],  },  plugins: [    new HtmlWebpackPlugin({      template: './public/index.html',    }),  ],  devServer: {    contentBase: path.join(__dirname, 'dist'),    compress: true,    port: 9000,  },};

配置 Babel:

创建 .babelrc 文件:

{  "presets": ["@babel/preset-env", "@babel/preset-react"]}

启动开发服务器:

npx webpack serve

总结

Vite 和 Webpack 都能胜任创建无CRA的React应用。Vite 提供更快速、简单的设置,适合小型项目和快速原型开发;Webpack 则提供更强大的可配置性和丰富的生态系统,适合复杂项目。 选择最适合您项目需求的工具。 祝您编码愉快!

以上就是如何在 CRA 弃用后创建 React 应用程序的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1499895.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月19日 22:08:02
下一篇 2025年12月19日 22:08:10

相关推荐

  • 我在几个小时内建立了一个电影流媒体网站 - 这是它的进展情况

    48小时速成电影流媒体网站:开发历程分享 最近,我尝试了一个极具挑战性的个人项目:在48小时内,仅使用React前端框架和一些API,搭建一个无需后端和数据库的电影流媒体网站。 灵感源于我发现的一些利用TMDB等API和vidsrc.dev进行视频流传输的简易电影网站。 这个项目的目标并非追求完美代…

    2025年12月19日
    000
  • 使用 YUP 进行表单验证

    使用Yup简化React表单验证 构建Web应用时,表单验证是确保数据完整性的关键步骤。如果您正在寻找一种简单而有效的方法来验证React表单,那么Yup是您的理想选择!本教程将指导您如何设置Yup,并创建一个经过良好验证的表单。 您将学到什么 阅读本教程后,您将掌握以下技能: 在React项目中配…

    2025年12月19日
    000
  • React Fragments:无需额外 DOM 节点即可对元素进行分组

    React Fragments:精简代码,提升性能 React Fragments 是一种轻量级方法,用于在不增加额外DOM节点的情况下对多个元素进行分组。当您需要从组件返回多个元素,而不想引入可能影响样式或布局的额外父元素时,它非常有用。 1. 什么是React Fragments? React …

    2025年12月19日
    000
  • 确保 Angular 项目的可访问性的简单步骤

    构建更具包容性的应用程序:从可访问性表单开始 在软件开发中,我们常常专注于功能交付,而忽略了可访问性和测试等重要方面(测试将在另一篇文章中详细讨论)。本文将重点探讨可访问性,它不仅仅关乎残障人士,更能提升所有用户的体验。 我最近深入学习了可访问性,并强烈推荐以下免费课程: 学习可访问性:https:…

    2025年12月19日 好文分享
    000
  • 使用 JavaScript 图形释放创造力:Canvas、SVG 和 WebGL 指南

    JavaScript 图形:赋能网页视觉盛宴 JavaScript 的图形能力让开发者在网页应用中实现令人惊艳的视觉效果、互动设计和动态动画。Canvas API、WebGL 和 SVG 的完美结合,使 JavaScript 成为游戏、数据可视化和创意设计等图形密集型应用的强大引擎。 核心图形工具 …

    2025年12月19日
    000
  • 掌握 React 中的 SASS/SCSS:综合指南

    React 项目中高效使用 SASS/SCSS SASS (Syntactically Awesome Style Sheets) 和 SCSS (Sassy CSS) 是强大的 CSS 预处理器,它们扩展了 CSS 的功能,赋予开发者变量、嵌套、mixin 和函数等特性,从而编写更简洁、可维护的样…

    2025年12月19日
    000
  • 将 Ant Design 与 React 结合使用的综合指南

    Ant Design (antd) 是一个基于 React 的流行 UI 组件库,提供一系列高质量、预设样式且可高度定制的组件,帮助开发者快速构建美观易用的 React 应用界面。Ant Design 遵循 Material Design 原则,确保应用界面风格的一致性和现代感。 Ant Desig…

    2025年12月19日
    000
  • React 中的 Chakra UI 入门:完整指南

    Chakra UI 是一个广受欢迎的 React 开源组件库,提供一系列易于访问、可复用且高度可定制的 UI 组件。它以简洁、模块化和无障碍设计为核心,帮助开发者轻松构建美观且一致的用户界面。Chakra UI 利用 CSS-in-JS 的强大功能进行样式处理,能与 React 应用无缝集成。 Ch…

    2025年12月19日
    000
  • 初学者指南中如何开始 Web 开发

    2024年,Web开发领域机遇无限!无论您是想要创建个人网站还是开发尖端应用,现在都是学习Web开发的绝佳时机。本指南将带您从零基础开始,开启您的Web开发之旅。 2024年学习Web开发的理由 互联网时代,网站无处不在!企业、博客、电商平台都需要熟练的Web开发者。学习Web开发,您将拥有广阔的职…

    2025年12月19日
    000
  • 联系我们-页面-React

    此项目是一个使用React.js构建的现代化联系页面,包含美观的联系表单、联系信息以及动画效果,旨在提升用户体验。 主要功能: 互动式联系表单: 表单带有流畅的动画和交互元素。清晰的联系方式: 提供联系邮箱、电话号码和详细地址。自适应设计: 确保在各种设备上都能完美显示。 技术栈: React.js…

    2025年12月19日
    000
  • js必会知识点

    要学好 JavaScript,你需要掌握的基础知识包括:JavaScript 的基本概念(变量、数据类型、运算符)控制流(循环、条件语句)函数(闭包、高阶函数)对象和原型链(继承、this 关键字) JavaScript:你必须掌握的那些事儿 很多初学者问:JavaScript到底要学啥? 这问题问…

    2025年12月19日
    000
  • js必须掌握的知识点

    JavaScript 核心知识点:基础:DOM 操作事件循环机制原型链进阶:闭包作用域高阶函数 JS必须掌握的知识点?这问题问得妙啊! 很多初学者觉得JavaScript这玩意儿,上手容易精通难,到处都是坑。其实,精通任何一门语言都不容易,关键在于找到学习的脉络,抓住核心。这篇文章,我打算从一个老码…

    2025年12月19日
    000
  • 人工智能发音训练器

    在本文中,我介绍了我正在从事的项目:AI Pronunciation Trainer(在线),这是一个旨在帮助您利用人工智能的力量提高发音的工具。这个项目是对 Thiagohgl 原始 AI Pronunciation Trainer 的重构,我对其进行了一些改进,以使该工具更有效且更易于使用。 它…

    2025年12月19日
    000
  • 我如何开始作为 MERN 堆栈开发人员的旅程

    简介: “我记得第一次遇到 MERN Stack 这个术语时——MongoDB、Express.js、React.js 和 Node.js。我不知道这些工具是什么,但我知道如果我能掌握它们,我就能够构建一些令人惊叹的网络应用程序。这是我如何从初学者到深入研究 MERN Stack 开发世界的故事。”…

    2025年12月19日
    000
  • 那天下雪了! ❄️

    我喜欢错综复杂的雪花。噢,它们旋转着、跳舞着,多么优雅地坠落啊!今天就和 animejs 一起下雪吧! 顾名思义,这个库允许您对几乎所有内容进行动画处理:从 css 值和 dom 属性到变量。 让我们创建一个简单的 html 文件,例如index.html: anime import anime f…

    2025年12月19日
    000
  • 你好开发社区

    我很高兴能够作为前端开发人员在这里创建我的第一篇文章。我期待与志同道合的人联系、分享知识并向他人学习。 关于我的一些信息:我热衷于构建响应灵敏、用户友好的界面,并了解最新的前端趋势和技术。我精通 HTML、CSS、JavaScript 以及 React 和 Angular 等框架。 **我有兴趣讨论…

    2025年12月19日
    000
  • 使用 Nextjs Tailwind CSS、Prisma、Open AI 和 Clerk 构建的 AI 旅行规划应用程序

    人工智能旅行规划师 使用 next.js 15、tailwind css、prisma、open ai 和 clerk 构建的 ai 旅行规划应用程序。功能包括用户注册、登录、生成旅行计划、查看所有旅行计划和删除行程。在开发过程中接受贡献。 入门 克隆存储库:git clone https://gi…

    2025年12月19日
    000
  • 在 React JS 项目中设置 Tailwind CSS

    如果您还没有 react 应用程序,请创建一个: npx create-react-app my-appcd my-app 安装 tailwind css运行以下命令安装 tailwind css 及其依赖项: npm install -d tailwindcss postcss autoprefi…

    2025年12月19日
    000
  • Osita 是一位熟练的开发人员,擅长 JavaScript,在 React、Node、Express 方面拥有专业知识

    欢迎来到我的世界 大家好,我是 Christopher Osita,一位充满激情的全栈开发人员、企业家,也是 Siitecch(发音为“see-tech”)背后的创造力。我的职业生涯致力于让技术变得简单、易于使用且有意义。无论您来这里是为了更多地了解我的旅程、我的专业知识,还是我对未来的愿景,欢迎光…

    2025年12月19日
    000
  • JavaScript 5 期热门面试问题和答案

    要破解 JavaScript 面试问题,您需要了解一些基本且重要的问题。这些问题将帮助您应对任何面试或技术考试。在这篇文章中,我提到了与 JavaScript 相关的前 20 个问题。 1. JavaScript 的定义是什么? JavaScript 是一种动态编程语言。它用于创建动态网页。您可以将…

    好文分享 2025年12月19日
    000

发表回复

登录后才能评论
关注微信