0

0

Nextjs App Router:包含真实示例的综合指南

心靈之曲

心靈之曲

发布时间:2024-10-17 22:27:16

|

954人浏览过

|

来源于dev.to

转载

nextjs app router:包含真实示例的综合指南

next.js 以其强大的功能和直观的设计彻底改变了 react 开发。随着 next.js 13 的发布,新的 app router 占据了中心舞台,为开发人员提供了更灵活、更强大的方式来构建应用程序。在这份综合指南中,我们将深入研究 app router,探索其功能和最佳实践。为了说明这些概念,我们将使用一个真实的示例:求职信生成器项目。

了解应用程序路由器

next.js 13 中的 app router 代表了我们在 react 应用程序中处理路由方式的范式转变。与之前的 pages router 不同,app router 使用基于文件系统的方法,该方法更符合我们对应用程序结构进行心理建模的方式。

应用路由器的主要优点:

  1. 直观的基于文件的路由:路由由应用程序目录中的文件结构定义。
  2. 改进的性能:对 react 服务器组件的内置支持。
  3. 增强灵活性:更轻松地实现布局、嵌套路由等。
  4. 内置优化:自动代码分割和预取。

应用路由器入门

让我们首先使用 app router 设置一个新的 next.js 13 项目。打开终端并运行:

npx create-next-app@latest my-app
cd my-app

出现提示时,请务必为“您想使用 app router 吗?”选择“是”。

使用 app router 进行基本路由

在 app router 中,每个文件夹代表一个路由段。让我们为求职信生成器创建一个简单的结构:

app/
├── page.tsx
├── layout.tsx
├── cover-letter/
│   └── page.tsx
└── templates/
    └── page.tsx

这里,根应用程序文件夹中的 page.tsx 代表主页。求职信和模板文件夹为这些各自的页面创建路线。

在 app/page.tsx 中:

export default function home() {
  return 

welcome to the cover letter generator

; }

在 app/cover-letter/page.tsx 中:

export default function coverletter() {
  return 

create your cover letter

; }

通过此结构,您可以导航到 / 访问主页,导航到 /cover-letter 访问求职信创建页面。

布局和嵌套路由

app router 的强大功能之一是能够创建嵌套布局。让我们为我们的应用程序添加一个通用布局。

在 app/layout.tsx 中:

export default function rootlayout({
  children,
}: {
  children: react.reactnode
}) {
  return (
    
      
        
        {children}
      
    
  );
}

此布局将应用于我们应用程序中的所有页面,提供一致的导航结构。

动态路线

动态路由对于基于参数生成内容的应用程序至关重要。让我们实现一个动态路由来查看特定的求职信模板。

创建一个新文件:app/templates/[id]/page.tsx:

export default function template({ params }: { params: { id: string } }) {
  return 

template {params.id}

; }

现在,导航到 /templates/1 或 /templates/formal 将使用相应的 id 渲染此组件。

服务器组件和数据获取

next.js 13 引入了 react server 组件,允许我们在服务器上获取数据。让我们在求职信生成器中实现这一点。

DALL·E 2
DALL·E 2

OpenAI基于GPT-3模型开发的AI绘图生成工具,可以根据自然语言的描述创建逼真的图像和艺术。

下载

在 app/cover-letter/page.tsx 中:

async function gettemplates() {
  // simulate api call
  return [
    { id: 1, name: 'professional' },
    { id: 2, name: 'creative' },
    { id: 3, name: 'academic' },
  ];
}

export default async function coverletter() {
  const templates = await gettemplates();

  return (
    

create your cover letter

    {templates.map(template => (
  • {template.name}
  • ))}
); }

该组件在服务器上获取数据,从而提高性能和 seo。

链接和导航

对于客户端导航,请使用 next.js 中的 link 组件。更新您的 app/layout.tsx:

import Link from 'next/link';

export default function RootLayout({
  children,
}: {
  children: React.ReactNode
}) {
  return (
    
      
        
        {children}
      
    
  );
}

实际应用:求职信生成器

现在我们已经介绍了基础知识,让我们看看如何将这些概念应用到实际项目中。 github 上的 resumate-nextjs 项目是使用 next.js 构建的求职信生成器的绝佳示例。

该项目的要点:

  1. 结构化路由:该项目使用清晰的路由结构,分离不同页面和组件之间的关注点。

  2. 服务器端渲染:利用 next.js 的 ssr 功能来提高性能和 seo。

  3. api 路由:为服务器端逻辑实现 api 路由,演示如何处理表单提交和数据处理。

  4. 样式:使用 tailwind css 进行响应式且简洁的 ui 设计。

  5. 状态管理:实现上下文 api 以管理跨组件的应用程序状态。

先进理念

当您对 app router 越来越熟悉时,请探索这些高级概念:

  1. 并行路由:以同一布局渲染多个页面。
  2. 拦截路由:针对特定场景自定义路由行为。
  3. 路由处理程序:在 app router 结构中创建 api 端点。
  4. 中间件:将自定义服务器端逻辑添加到您的路由中。

最佳实践和技巧

  1. 利用服务器组件:使用它们进行数据获取和繁重计算。
  2. 优化图片:使用next.js image组件进行自动优化。
  3. 实施渐进增强:确保您的应用程序无需 javascript 即可运行,以获得更好的可访问性。
  4. 使用 typescript:提高开发者体验和代码质量。
  5. 定期更新:保持 next.js 版本更新,以便从最新功能和优化中受益。

结论

next.js 13 app router 代表了 react 应用程序开发向前迈出的重要一步。通过提供直观的、基于文件系统的路由系统并利用 react server components 的强大功能,它使开发人员能够构建高性能、可扩展且可维护的 web 应用程序。

正如求职信生成器示例所示,app router 简化了创建复杂、动态 web 应用程序的过程。无论您是构建简单的作品集网站还是复杂的 web 应用程序,掌握 app router 都将显着增强您的 next.js 开发体验。

记住,最好的学习方法就是实践。克隆 resumate-nextjs 存储库,试验代码,并尝试使用 app router 实现您自己的功能。快乐编码!

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
什么是中间件
什么是中间件

中间件是一种软件组件,充当不兼容组件之间的桥梁,提供额外服务,例如集成异构系统、提供常用服务、提高应用程序性能,以及简化应用程序开发。想了解更多中间件的相关内容,可以阅读本专题下面的文章。

178

2024.05.11

Golang 中间件开发与微服务架构
Golang 中间件开发与微服务架构

本专题系统讲解 Golang 在微服务架构中的中间件开发,包括日志处理、限流与熔断、认证与授权、服务监控、API 网关设计等常见中间件功能的实现。通过实战项目,帮助开发者理解如何使用 Go 编写高效、可扩展的中间件组件,并在微服务环境中进行灵活部署与管理。

216

2025.12.18

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

514

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

244

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

299

2023.08.03

js是什么意思
js是什么意思

JS是JavaScript的缩写,它是一种广泛应用于网页开发的脚本语言。JavaScript是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

5326

2023.08.17

js删除节点的方法
js删除节点的方法

js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

481

2023.09.01

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

212

2023.09.04

java入门学习合集
java入门学习合集

本专题整合了java入门学习指南、初学者项目实战、入门到精通等等内容,阅读专题下面的文章了解更多详细学习方法。

1

2026.01.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.1万人学习

CSS教程
CSS教程

共754课时 | 25万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号