Next.js第三章(App Router)

Next.js 路由概览

Next.js 使用基于文件系统的路由,这意味着文件和文件夹的结构直接决定了应用的路由结构。

基于文件系统的路由

我们只需要创建对应的文件和文件夹,Next.js 会自动生成对应的路由。

在 Next.js 中,每个文件夹代表一个路由段,映射到 URL 段:

page

bash 复制代码
app/
├── page.tsx               # /
├── about/
│   └── page.tsx           # /about
├── blog/test
│        └── page.tsx      # /blog/test
└── contact/
    └── page.tsx           # /contact

layout && template

layout(布局) 布局是多个页面共享UI,例如导航栏、侧边栏、底部等。

template(模板) 基本功能跟布局一样,只是不会保存状态

布局和模板的特点就是:

  • 多个布局可以嵌套
  • 布局会保存状态 / 模板不会保存状态
  • 根布局(必须存在)
  • 如果布局和模板同时存在,则布局会优先于模板 layout->template-page

目录结构如下:

txt 复制代码
app
└─ blog
   ├─ layout.tsx
   ├─ template.tsx
   ├─ a
   │  └─ page.tsx
   └─ b
      └─ page.tsx

app/blog/layout.tsx

tsx 复制代码
'use client' //需要交互的地方要改为客户端组件 默认是服务端组件
import { useState } from "react"
export default function BlogLayout({ children }: { children: React.ReactNode }) {
    const [count, setCount] = useState(0)
    return (
        <div>
            <h1>Blog 布局组件</h1>
            <button onClick={() => setCount(count + 1)}>+1</button>
            <h1>数量: {count}</h1>
            <hr />
            {children}
        </div>
    )
}

app/blog/template.tsx

tsx 复制代码
'use client' //需要交互的地方要改为客户端组件 默认是服务端组件
import { useState } from "react"
export default function BlogTemplate({ children }: { children: React.ReactNode }) {
    const [count, setCount] = useState(0)
    return (
        <div>
            <h1>Blog Template</h1>
            <button onClick={() => setCount(count + 1)}>+1</button>
            <h1>数量: {count}</h1>
            <hr />
            {children}
        </div>
    )
}

app/blog/a/page.tsx

tsx 复制代码
import Link from "next/link"
export default function APage() {
    return (
        <div>
            <h1>A Page</h1>
            <Link href="/blog/b">跳转B</Link>
        </div>
    )
}

app/blog/b/page.tsx

tsx 复制代码
import Link from "next/link"
export default function BPage() {
    return (
        <div>
            <h1>B Page</h1>
            <Link href="/blog/a">跳转A</Link>
        </div>
    )
}

loading(加载)

Next.js的loading是借助了Suspense实现的,Suspense的具体用法请参考Suspense 组件

app/blog/loading.tsx

tsx 复制代码
export default function Loading() {
    return (
        <div>
            <h1>Loading...</h1>
        </div>
    )
}

app/blog/a/page.tsx

tsx 复制代码
import Link from "next/link"
const getData = async () => {
  //触发异步会自动跳转到loading组件 异步结束正常返回页面
  return new Promise((resolve) => {
    setTimeout(() => {
      resolve("数据")
    }, 5000)
  })
}
export default async function APage() {
    const data = await getData()
    console.log(data)
    return (
        <div>
            <h1>A Page</h1>
            <Link href="/blog/b">跳转B</Link>
        </div>
    )
}

error(错误)

Next.js的error是借助了Error Boundary实现的。

app/blog/error.tsx

tsx 复制代码
'use client' //错误组件必须是客户端组件
export default function Error() {
    return (
        <div>
            <h1>Error</h1>
        </div>
    )
}

app/blog/a/page.tsx

tsx 复制代码
import Link from "next/link"
export default async function APage() {
   //遇到异常会自动跳转到error组件
    throw new Error("错误")
    return (
        <div>
            <h1>A Page</h1>
            <Link href="/blog/b">跳转B</Link>
        </div>
    )
}

not-found(404)

其实Next.js 默认会生成一个404页面,但我们可能自定义404页面,只需要在app目录下创建一个not-found.tsx文件即可

app/not-found.tsx

tsx 复制代码
export default function NotFound() {
    return (
        <div>
            <h1>404 Page</h1>
        </div>
    )
}

预计学习时间 : 20 分钟
难度级别: 初级 🟢

相关推荐
程序员码歌3 小时前
短思考第261天,浪费时间的十个低效行为,看看你中了几个?
前端·ai编程
Swift社区4 小时前
React Navigation 生命周期完整心智模型
前端·react.js·前端框架
若梦plus4 小时前
从微信公众号&小程序的SDK剖析JSBridge
前端
用泥种荷花5 小时前
Python环境安装
前端
Light605 小时前
性能提升 60%:前端性能优化终极指南
前端·性能优化·图片压缩·渲染优化·按需拆包·边缘缓存·ai 自动化
Jimmy5 小时前
年终总结 - 2025 故事集
前端·后端·程序员
烛阴5 小时前
C# 正则表达式(2):Regex 基础语法与常用 API 全解析
前端·正则表达式·c#
roman_日积跬步-终至千里5 小时前
【人工智能导论】02-搜索-高级搜索策略探索篇:从约束满足到博弈搜索
java·前端·人工智能
GIS之路5 小时前
GIS 数据转换:使用 GDAL 将 TXT 转换为 Shp 数据
前端
多看书少吃饭5 小时前
从Vue到Nuxt.js
前端·javascript·vue.js