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

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

生产级的 React 框架

1. Next.js

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

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

2. Remix

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

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

3. Gatsby

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

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

4.Expo(用于原生应用)

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

//要创建一个新的 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 代码添加类型定义的常用方法。

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

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

{
  "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"
  ]
}

相关推荐

  1. React 如何启动一个项目

    2024-05-04 02:26:01       31 阅读
  2. 如何新建一个React前端项目

    2024-05-04 02:26:01       33 阅读
  3. React 】在React 项目如何捕获错误

    2024-05-04 02:26:01       46 阅读
  4. React 】 在React项目中是如何使用Redux

    2024-05-04 02:26:01       43 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-05-04 02:26:01       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-05-04 02:26:01       101 阅读
  3. 在Django里面运行非项目文件

    2024-05-04 02:26:01       82 阅读
  4. Python语言-面向对象

    2024-05-04 02:26:01       91 阅读

热门阅读

  1. python - mac安装mysqlclient

    2024-05-04 02:26:01       26 阅读
  2. 一步一步写线程之十一线程池应用内存池

    2024-05-04 02:26:01       33 阅读
  3. css实现瀑布流布局

    2024-05-04 02:26:01       32 阅读
  4. matlab绘制散点图

    2024-05-04 02:26:01       36 阅读
  5. L1-042 日期格式化

    2024-05-04 02:26:01       27 阅读
  6. 概述小样本学习的具体应用场景

    2024-05-04 02:26:01       32 阅读
  7. 寻找自己的25号底片

    2024-05-04 02:26:01       36 阅读
  8. 上海计算机学会2023年9月月赛C++丙组T1口令的分类

    2024-05-04 02:26:01       34 阅读
  9. 238. 除自身以外数组的乘积/41. 缺失的第一个正数

    2024-05-04 02:26:01       29 阅读
  10. 模型蒸馏吼吼吼

    2024-05-04 02:26:01       34 阅读