React 之 如何启动一个新的项目(六)

React本身是为构建SPA(单页面应用)而设计的。
想完全用 React 构建一个新的应用或网站,我们建议选择社区中流行的、由 React 驱动的框架。

生产级的 React 框架

1. Next.js

Next.js 的页面路由 是一个全栈的 React 框架。它用途广泛,可让你创建任何规模的 React 应用程序------从大部分的静态博客到复杂的动态应用程序。
你可以 将 Next.js 应用 部署到 Node.js 或 serverless 上,也可以部署到你自己的服务器上。完全静态的 Next.js 应用 可以部署在任何支持静态服务的地方。

javascript 复制代码
//要创建新的 Next.js 项目,请在终端中运行:
npx create-next-app@latest

2. Remix

Remix 是一个具有嵌套路由的全栈式 React 框架。它可以把你的应用分成嵌套部分,该嵌套部分可以并行加载数据并响应用户操作进行刷新。
当你创建一个 Remix 项目时,你需要 选择你的部署目标。你可以通过使用或编写 适配器 将 Remix 应用部署到 Node.js 或 serverless 上进行托管。

javascript 复制代码
//要创建一个新的 Remix 项目,请运行:
npx create-remix

3. Gatsby

Gatsby 是一个快速的支持 CMS 网站的 React 框架。其丰富的插件生态系统和 GraphQL 数据层简化了将内容、API 和服务整合到一个网站的过程。
你可以 部署一个完全静态的 Gatsby 网站 到任何一个支持静态服务的地方。如果你选择使用服务器上的功能,请确保你的主机供应商支持 Gatsby 的功能。

javascript 复制代码
//要创建一个新的 Gatsby 项目,请运行:
npx create-gatsby

4.Expo(用于原生应用)

Expo 是一个 React 框架,可以让你创建具有真正原生 UI 的应用,包括 Android、iOS,以及 Web 应用。它为 React Native 提供了 SDK,使原生部分更容易使用。
当你创建一个 Remix 项目时,你需要 选择你的部署目标。你可以通过使用或编写 适配器 将 Remix 应用部署到 Node.js 或 serverless 上进行托管。
用 Expo 构建应用是免费的,而且你可以不受限制地将它们提交到谷歌和苹果的应用商店。此外,Expo 还提供选择性的付费云服务。

javascript 复制代码
//要创建一个新的 Expo 项目,请运行:
npx create-expo-app

5.Next.js (App Router)

Next.js 的 App Router 是对 Next.js API 的重新设计,旨在实现 React 团队的全栈架构愿景。它让你在异步组件中获取数据,这些组件甚至能在服务端构建过程中运行。
你可以将 Next.js 应用 部署到 Node.js 或 serverless 主机上,或部署到你自己的服务器上。Next.js 还支持 静态导出,不需要服务器。

在现有 React 项目中添加 TypeScript

TypeScript 是一种向 JavaScript 代码添加类型定义的常用方法。

javascript 复制代码
//使用下面命令安装最新版本的 React 类型定义:
npm install @types/react @types/react-dom

然后在 tsconfig.json 中设置以下编译器选项:

javascript 复制代码
{
  "compilerOptions": {
    "target": "es5", //表示将TypeScript代码编译为ES5语法的JavaScript代码
    "lib": [  //lib字段指定了编译过程中需要包含的库文件。
      "dom",
      "dom.iterable",
      "esnext"
    ],
    "allowJs": true,  //允许在项目中包含JavaScript文件。
    "skipLibCheck": true,  //表示跳过所有声明文件的类型检查,这可以提高编译速度。
    "esModuleInterop": true,  //允许使用import foo from 'bar'语法来导入默认导出。
    "allowSyntheticDefaultImports": true,  //允许在导入时使用默认导入语法,即使模块没有默认导出。
    "strict": true,  //启用所有严格的类型检查选项。
    "forceConsistentCasingInFileNames": true,  //确保引用的文件大小写与实际文件大小写一致。
    "module": "esnext",  //使用最新的ECMAScript模块语法。
    "moduleResolution": "node",  //使用Node.js风格的模块解析。
    "resolveJsonModule": true,  //允许从.json文件中导入数据。
    "isolatedModules": true,  //表示每个文件应该单独编译,这有助于在编辑时提供更好的错误提示。
    "noEmit": true, //表示不输出文件,通常用于与编辑器集成以提供更好的错误和类型提示。
    "jsx": "react-jsx"  //这是React 17及以上版本推荐的JSX转换方式。
  },
  "include": [  //指定了需要编译的源文件所在的目录。在这个例子中,src目录包含了所有的源文件。
    "src"
  ]
}
相关推荐
Code_Dragon1 分钟前
最近遇到的bug
linux·前端
言兴1 分钟前
从输入 URL 到页面显示:深入理解浏览器缓存机制
前端·javascript·面试
讨厌吃蛋黄酥2 分钟前
前端跨域难题终结者:从JSONP到CORS,一文搞定所有跨域问题!
前端·javascript·后端
阿星做前端2 分钟前
coze源码解读:项目启动
前端·javascript
言兴3 分钟前
面试题之解析“类组件”与“组件”的本质
前端·javascript·面试
Jessica07063 分钟前
【Vue3+Element Plus】修改el-table树形结构的默认箭头样式
前端
excel4 分钟前
前端布局避坑指南:Grid、Flex 与传统 CSS2 布局的优缺点全解析
前端
潘小安6 分钟前
『译』2025 年 MCP 工具终极指南:6 款颠覆性 AI 开发工具,让你的生产力提升 10 倍
前端·ai编程·mcp
小林的技术分享6 分钟前
关于排查 Flutter 3.27.0 版本Android端无法禁用Impeller引擎的过程记录
前端·flutter
南篱8 分钟前
React 受控 vs 非受控组件:核心概念解析
前端·面试