Next.js第五章(动态路由)

动态路由

动态路由是指在路由中使用方括号[]来定义路由参数,例如/blog/[id],其中[id]就是动态路由参数,因为在某些需求下,我们需要根据不同的id来显示不同的页面内容,例如商品详情页,文章详情页等。

基本用法[slug]

使用动态路由只需要在文件夹名加上方括号[]即可,例如[id],[params]等,名字可以自定义。

来看demo: 我们在app/shop目录下创建一个[id]目录

tsx 复制代码
//app/shop/[id]/page.tsx
export default function Page() {
    return <div>Page</div>
}

访问路径为:http://localhost:3000/shop/123 其中123就是动态路由参数,这个可以是任意值。

路由片段[...slug]

我们如果需要捕获多个路由参数,例如/shop/123/456,我们可以使用路由片段来捕获多个路由参数,他的用法就是[...slug],其中slug就是路由片段,这个名字可以自定义,后面的片段有多少就捕获多少。

tsx 复制代码
//app/shop/[...id]/page.tsx
export default function Page() {
    return <div>Page</div>
}

访问路径为:http://localhost:3000/shop/123/456/789 其中123456789就是动态路由参数,后面的片段有多少就捕获多少。

可选路由[[...slug]]

可选路由指的是,我们可能会有这个路由参数,也可能会没有这个路由参数,例如/shop/123,也可能是/shop,我们可以使用可选路由来捕获这个路由参数,他的用法就是[[...slug]],其中slug就是路由片段,这个名字可以自定义,后面的片段有多少就捕获多少。

tsx 复制代码
//app/shop/[[...id]]/page.tsx
export default function Page() {
    return <div>Page</div>
}
  • 访问路径为:http://localhost:3000/shop,可以没有参数
  • 访问路径为:http://localhost:3000/shop/123,可以有参数
  • 访问路径为:http://localhost:3000/shop/123/456,可以有多个参数

这种方式比较灵活。

接受参数

使用useParams hook来接受参数,这个hook只能在客户端组件中使用。

tsx 复制代码
'use client'
import { useParams } from "next/navigation";
export default function ShopPage() {
  const params = useParams();
  console.log(params); //{id: '123'}  {id: ['123', '456']} 接受单个值以及多个值
  return <div>ShopPage</div>;
}
相关推荐
IT_陈寒2 分钟前
SpringBoot 项目启动慢?这5个优化技巧让你的应用快50%
前端·人工智能·后端
GISer_Jing12 分钟前
React核心语法:组件化与声明式编程
前端·react.js·前端框架
DJ斯特拉12 分钟前
文件上传(UUID防止重名文件&&阿里云实现云端上传&&MultipartFile接收前端文件)
前端
Alan Lu Pop17 分钟前
React 表单提交关键词意外触发刷新
前端·javascript·react.js
掘金安东尼19 分钟前
企业级Claw落地避坑指南:70%项目失败的真实原因
前端·面试·github
这儿有一堆花20 分钟前
从技术标准到营销概念:深度解析 HTML5 与 H5 的演变与区别
前端·html·html5
我命由我1234520 分钟前
React - 创建 React 项目、React 项目结构、React 简单案例、TodoList 案例
前端·javascript·react.js·前端框架·ecmascript·html5·js
SuperEugene22 分钟前
Vue3 Pinia 状态管理规范:何时用 Pinia 何时用本地状态|状态管理与路由规范篇
开发语言·前端·javascript·vue.js·前端框架
Moment23 分钟前
TypeScript 要换芯了,6.0 竟是旧编译器的最后一舞
前端·javascript·github
Cg1362691597428 分钟前
Element-入门
前端