《Learn Next.js 中文教程》来了!

《Learn Next.js 中文教程》是一个基于 Next.js App Router 架构的免费学习教程,通过构建全栈 Web 应用程序,可以让您更好的了解 Next.js 的主要功能

本系列是基于官方教程的一个中文翻译教程

在翻译、整理的过程中,每个章节对应的 Example 代码,笔者也都进行了测试,有问题的部分也进行了修改,参见 Github 项目 nextjs-learn-example

我们将要做的

在这个课程中,我们将构建一个财务 Dashboard 的简化版本,其中包含以下内容:

  • 一个公共首页。
  • 一个登录页面。
  • 受身份验证保护的仪表板页面。
  • 用户能够添加、编辑和删除发票。

该 Dashboard 还将有一个相应的数据库,在后面的章节中将对其进行设置。

通过本课程,您将掌握构建全栈 Next.js 应用程序所需的基本技能。

概述

以下是本课程中您将学到的功能:

  • Styling(样式化): 在 Next.js 中样式化应用程序的不同方法。
  • Optimizations(优化): 如何优化图像、链接和字体。
  • Routing(路由): 使用文件系统路由创建嵌套布局和页面。
  • Data Fetching(数据获取): 如何在 Vercel 上设置数据库,以及获取和流式传输的最佳实践。
  • Search and Pagination(搜索和分页): 如何使用 URL 搜索参数实现搜索和分页。
  • Mutating Data(数据突变): 如何使用 React Server Actions 操作数据,并重新验证 Next.js 缓存。
  • Error Handling(错误处理): 如何处理一般错误和 404 未找到错误。
  • Form Validation and Accessibility(表单验证和可访问性): 如何进行服务器端表单验证以及提高可访问性的提示。
  • Authentication(身份验证) : 如何使用 NextAuth.js 和中间件为应用程序添加身份验证。
  • Metadata(元数据): 如何添加元数据并为社交分享准备您的应用程序。

先决知识

本课程假设您对 React 和 JavaScript 有基本的了解。如果您是 React 的新手,我们建议您首先完成我们的 React 基础课程,以学习 React 的基础知识,如组件、props、state 和 hooks,以及像 Server Components 和 Suspense 这样的新功能。

系统要求

在开始本课程之前,请确保您的系统满足以下要求:

  • 安装 Node.js 18.17.0 或更高版本。下载地址
  • 操作系统:macOS、Windows(包括WSL)或Linux。

另外,您还需要一个 GitHub 账号和一个 Vercel 账号。(Vercel 是用来部署用的,如果服务只是在本地运行,做为学习使用,Vercel 账号也不是必须的)。

如果本教程能为您得到帮助,请给予项目 Learn Next.js 中文教程 一个 ★ 做为支持!

相关推荐
码路飞23 分钟前
热榜全是 OpenClaw,但我用 50 行 Python 就造了个桌面 AI Agent 🤖
java·javascript
前端Hardy1 小时前
别再忽略 Promise 拒绝了!你的 Node.js 服务正在“静默自杀”
前端·javascript·面试
前端Hardy1 小时前
别再被setTimeout闭包坑了!90% 的人都写错过这个经典循环
前端·javascript·vue.js
前端Hardy1 小时前
你的 Vue 组件正在偷偷吃掉内存!5 个常见的内存泄漏陷阱与修复方案
前端·javascript·面试
前端人类学1 小时前
深入解析JavaScript中的null与undefined:区别、用法及判断技巧
前端·javascript
进击的尘埃3 小时前
Vitest 自定义 Reporter 与覆盖率卡口:在 Monorepo 里搞增量覆盖率检测
javascript
进击的尘埃3 小时前
E2E 测试里的网络层,到底该怎么 Mock?
javascript
DevUI团队4 小时前
🚀 【Angular】MateChat V20.2.2版本发布,新增8+组件,欢迎体验~
前端·javascript·人工智能
嚴寒4 小时前
前端配环境配到崩溃?这个一键脚手架让我少掉了一把头发
前端·react.js·架构
DevUI团队4 小时前
🚀 MateChat V1.11.0 震撼发布!新增工具按钮栏组件及体验问题修复,欢迎体验~
前端·javascript·人工智能