当前位置: 首页 > news >正文

Next.js第四章(路由导航)

路由导航

路由导航是指我们在Next.js中跳转页面的方式,例如原始的<a>标签,等。

在Next.js中,共有四种方式提供跳转:

  • Link组件
  • useRouter Hook (客户端组件)
  • redirect函数 (服务端组件)
  • History API (浏览器API 本文略过用的不多 了解即可)

Link组件

<Link>是一个内置组件,在a标签的基础上扩展了功能,并且还能用来实现预获取(prefetching),以及保持滚动位置(scroll)等。

基本用法

import Link from "next/link" //引入Link组件
export default function Home() {return (<div><Link href="/about">跳转About页面</Link><Link href={{pathname: "/about", query: {name: "张三"}}}>跳转About并且传入参数</Link><Link href="/page" prefetch={true}>预获取page页面</Link><Link href="/xm" scroll={true}>保持滚动位置</Link><Link href="/daman" replace={true}>替换当前页面</Link></div>)
}

支持动态渲染

import Link from "next/link"
export default function Page() {const arr = [1, 2, 3, 4, 5]return arr.map((item) => (<Link key={item} href={`/page/${item}`}>动态渲染的Link</Link>))
}

useRouter Hook

useRouter 可以在代码中根据逻辑跳转页面,例如根据用户权限跳转不同的页面。

使用该hook需要在客户端组件中。需要在顶层编写 'use client' 声明这是客户端组件。

'use client'
import { useRouter } from "next/navigation"
export default function Page() {const router = useRouter()return (<><button onClick={() => router.push("/page")}>跳转page页面</button><button onClick={() => router.replace("/page")}>替换当前页面</button><button onClick={() => router.back()}>返回上一页</button><button onClick={() => router.forward()}>跳转下一页</button><button onClick={() => router.refresh()}>刷新当前页面</button><button onClick={() => router.prefetch("/about")}>预获取about页面</button></>)
}

redirect 函数

redirect 函数可以用于服务端组件/客户端组件中跳转页面,例如根据用户权限跳转不同的页面。

在Next.js中 redirect的状态是:307临时重定向

import { redirect } from "next/navigation"
export default async function Page() {const checkLogin = await checkLogin()//如果用户未登录,则跳转到登录页面if (!checkLogin) {redirect("/login")}return (<div><h1>Page</h1></div>)
}

permanentRedirect 函数

permanentRedirect 跟上面的redirect的区别是:permanentRedirect是永久重定向,而redirect是临时重定向。

在Next.js中 permanentRedirect的状态是:308永久重定向

//用法跟redirect一样,只是状态码不同
import { permanentRedirect } from "next/navigation"
export default async function Page() {const checkLogin = await checkLogin()if (!checkLogin) {permanentRedirect("/login")}
}

permanentRedirect / redirect 注意事项

  • path 字符串类型,表示重定向的 URL,可以是相对路径,也可以是绝对路径
  • type 值为 replace (默认)或者 push(Server Actions 中默认),表示重定向的类型

permanentRedirectredirect 在 Sever Actions 中会用 push添加到浏览器历史,在其他地方用 replace在浏览器历史栈中替换当前的 URL。你可以通过指定 type参数覆盖此行为。

注意:在服务端组件中使用 type参数没有效果。

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

http://www.dtcms.com/a/601357.html

相关文章:

  • 从jsp打开一个html,怎么把jsp的某些参数传递给html
  • 谷歌google官方网站网站开发 书籍
  • 北京网站备案公司安徽观元建设有限公司网站
  • 若依plus请求加解密
  • PHP Filter:深入了解其功能与实现
  • Linux基础指令(简易版)
  • 农田灌区监测设备:赋能现代农业的精准感知与智能调控
  • 中山 灯饰 骏域网站建设专家百度关键词推广帝搜软件
  • 自己怎么做 优惠券网站西京一师一优课建设网站
  • CST电动车EMC仿真(二)——电机控制器MCU的EMC仿真
  • WPP Media(群邑)DOOH 解决方案 重构数字户外广告价值
  • 基于SpringBoot+Vue的美容美发在线预约系统的设计与实现【附源码】
  • 数字化转型改变了什么?从技术底层到业务本质的深度重构
  • 从 “被动抢修” 到 “主动防控”,安科瑞 mini 智能微断,重构末端配电安全新逻辑
  • 从经验到算法:智能获客系统如何重构ToB销售效率
  • Oracle 19C 数据字典 DBA_HIST_SEG_STAT 详细说明
  • tsfile.raw提示
  • JAVA中六种策略模式的实现
  • 【ZeroRange WebRTC】TLS 底层原理与工作机制(深入解析)
  • 【论文阅读16】-LLM-TSFD:一种基于大型语言模型的工业时间序列人机回路故障诊断方法
  • 联想键盘失灵处理方法
  • 网站建设scyiyouhtml5模板之家
  • 做网站网络公司泉州住房建设局网站
  • 电子绕核运动为何不辐射能量、不坠入原子核?
  • RK3588核心板/开发板RT-Linux系统实时性及硬件中断延迟测试
  • 11. 函数极限
  • 死锁的本质:形成条件、检测机制与排查策略
  • Winform控件:RichTextBox
  • 大疆影石掰手腕,智能影像“跨界”内卷
  • 建设一个网站平台一款app的开发成本