【NextJS】路由之拦截路由(Intercepting Routes) - 简仿花瓣网

在这里插入图片描述

拦截路由(Intercepting Routes)

@link: https://nextjs.org/docs/app/building-your-application/routing/intercepting-routes

  • 概念
    拦截路由允许在当前布局中加载应用程序其他部分的路由,即在不切换用户上下文的情况下显示路由内容。例如,在信息流中点击照片时,可以在模态框中显示照片,覆盖信息流,此时 Next.js 拦截 /photo/123 路由,掩盖 URL 并覆盖在 /feed 上。

  • 路由约定(路由文件夹结构)
    以特定的文件夹结构来组织拦截路由相关的代码。

    • 使用 (..) 约定来定义拦截路由,类似于相对路径约定 ../ 但用于路由段。

      • (.) 匹配同一级别的段,(..) 匹配上一级别的段,
      • (..)(..) 匹配上两级别的段,
      • (...) 匹配从根应用目录开始的段。


      例如,可通过创建 (..)photo 目录从 feed 段中拦截 photo 段。
      注:该约定基于路由段而非文件系统。

注意导航方式

  • 软导航
    通过点击信息流中的照片等客户端导航方式,在模态框中显示内容,此时进行路由拦截。
  • 硬导航
    通过点击可分享 URL 或刷新页面导航到照片时,应渲染整个照片页面,不进行路由拦截。

实践中认识

直观效果: 可以参见“花瓣网”的图片列表->图片详情的样式与路由变化

下面简单仿制花瓣网界面布局用于认识NextJS拦截路由(Intercepting Routes)

准备环境

  • react: ^18
  • next: 14.2.20
  • tailwindcss: ^3.4.1
  • typescript: ^5

在这里插入图片描述
页面样式跳过,文末有完整项目代码

目录结构

app目录下目录结构准备

在这里插入图片描述

代码

效果表现

示例效果
步骤:

  • 从列表随机选择一个进入详情页
  • 此时详情页的路由地址被打开 (注: 此时样式类似Modal 对话框的表现形式,层叠原有列表页面上)
  • 当重新刷新页面时,似乎进到了“全新的页面”上

这种表现形式,在Next.js框架中称为拦截路由(Intercepting Routes)

重点部分

在上面目录结构上,是否好奇search目录下的@modal(..)pins这类奇奇怪怪的目录名称?下面重点解释解释

  • @modal命名粗暴理解的话也可以当作是路由组的另一种表达形式(规则:@ + [name] 命名)
    也就是《Parallel Routes:Tab Groups》,并行路由里提到的标签组的概念;

  • (..)pins命名就是拦截路由的关键了,这里表达的是:

    • 在上游是/search路由下访问/pins/[id]路由的拦截指向
    • pins目录和search是同级的,则../pins就可以找到(类似文件系统里的相对路径)
    • 注:@[name]规则的目录是被忽略层级
      并且拦截路径要和目标路由路径保持一致(例:(..)pins/[id]pins/[id])

除了上面两部分特殊命名外,还需要default.tsxlayout.tsx的辅助,才能最终完成整体的效果;

default.tsx部分

  • 并行路由:default.js
  • 文件约定:default.js

layout.tsx部分

在要进行拦截的路由下建立(就像上面的/search路由下要拦截/pins/[id]这种情景下);

建立layout文件的目的是为了拦截路由后的呈现(为目标路由内容呈现预留“插槽”位置)

// file: app/(root)/search/layout.tsximport type {ReactNode} from "react";const PageLayout = function (props: Readonly<{children: ReactNode,modal: ReactNode
}>) {const {children, modal} = props;return (<>{children}{modal}</>)
}export default PageLayout;

至此几个要点部分应该都说到了,有啥不足评论区里一起探讨探讨!

完整代码可移步到《GitCode: demo-Intercepting-routes》项目上

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/489228.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Vulkan入门】14-ShowBySDL

文章目录 先叨叨关键代码Git信息main.cpp 运行结果接下来我会做什么重构代码在b站出一套视频 先叨叨 上篇我们让Vulkan渲染了一个三角形&#xff0c;但还没有把它显示出来。本篇介绍一下&#xff0c;如何使用SDL将这个图形显示出来。 原理其实很简单&#xff0c;就是将渲染的内…

GESP202412 四级【Recamán】题解(AC)

》》》点我查看「视频」详解》》》 [GESP202412 四级] Recamn 题目描述 小杨最近发现了有趣的 Recamn 数列&#xff0c;这个数列是这样生成的&#xff1a; 数列的第一项 a 1 a_1 a1​ 是 1 1 1&#xff1b;如果 a k − 1 − k a_{k-1}-k ak−1​−k 是正整数并且没有在数…

OpenCV实验:图片加水印

第二篇&#xff1a;图片添加水印&#xff08;加 logo&#xff09; 1. 实验原理 水印原理&#xff1a; 图片添加水印是图像叠加的一种应用&#xff0c;分为透明水印和不透明水印。水印的实现通常依赖于像素值操作&#xff0c;将水印图片融合到目标图片中&#xff0c;常用的方法…

OpenCV 功能函数介绍 (二)

一&#xff0c;梯度处理的sobel算子函数 功能&#xff1a; 用于计算图像梯度&#xff08;gradient&#xff09;的函数 参数&#xff1a; cv2.Sobel(src, ddepth, dx, dy, ksize3, scale1, delta0, borderTypeNone) cv2.Sobel&#xff08;输入图像 &#xff0c; 应该是灰…

MySQL有哪些高可用方案?

大家好&#xff0c;我是锋哥。今天分享关于【MySQL有哪些高可用方案?】面试题。希望对大家有帮助&#xff1b; MySQL有哪些高可用方案? 1000道 互联网大厂Java工程师 精选面试题-Java资源分享网 MySQL 高可用方案旨在确保数据库系统的高可靠性、低宕机时间、以及在硬件故障…

鸿蒙项目云捐助第二讲鸿蒙图文互动基本程序实现

鸿蒙项目云捐助第二讲鸿蒙图文互动基本程序实现 结合第一讲建立的“Hello World”程序&#xff0c;得到如下图所示的界面。 这里的“Hello World”是通过“Priview”显示出来的。在这个界面中进行开发的前奏曲&#xff0c;可以通过点击更换图片的案例来体会一下鸿蒙Next的开发…

厦门凯酷全科技有限公司正规吗靠谱吗?

随着短视频和直播电商的迅猛发展&#xff0c;越来越多的企业开始将目光投向抖音这一平台。作为国内领先的短视频社交平台&#xff0c;抖音凭借其庞大的用户基础和强大的算法推荐系统&#xff0c;成为众多品牌拓展市场、提升销售的重要渠道。厦门凯酷全科技有限公司&#xff08;…

计算机网络从诞生之初到至今的发展历程

前言 "上网"&#xff0c;相信大家对这个动词已经不再陌生&#xff0c;网 通常指的是网络&#xff1b;在 2024 年的今天&#xff0c;网络已经渗透到了每个人的生活中&#xff0c;成为其不可或缺的一部分&#xff1b;你此时此刻在看到我的博客&#xff0c;就是通过网络…

django——admin后台管理1

一、admin后台管理 访问url进入&#xff1a; http://127.0.0.1:8000/admin ​ 创建超级管理用户 终端输入以下命令&#xff1a; python manage.py createsuperuser (py36_pingping) E:\django学习\day03-django入门\demo>python manage.py createsuperuser Username: mo…

如何保证数据库和缓存双写一致性?

数据库和缓存&#xff08;redis&#xff09;双写数据一致性问题再高并发的场景下&#xff0c;是一个很严重的问题&#xff0c;无论在工作中&#xff0c;还是面试&#xff0c;遇到的概率非常大&#xff0c;这里就聊一聊目前的常见解决方案以及最优方案。 常见方案 缓存的主要目…

Java基础知识(四) -- 面向对象(上)

1.概述 Java语言是一种面向对象的程序设计语言&#xff0c;而面向对象思想(OOP)是一种程序设计思想&#xff0c;在面向对象思想的指引下&#xff0c;使用Java语言去设计、开发计算机程序。这里的对象泛指现实中一切事物&#xff0c;每种事物都具备自己的属性和行为。 面向对象思…

【数据结构与算法】Java描述:学数据结构与算法你需要预备的知识点!!!

这篇文章主要介绍 什么是数据结构&#xff0c;算法的时间复杂度&#xff0c;空间复杂度计算&#xff0c;包装类的装箱拆箱&#xff0c; 泛型语法&#xff0c;以及擦除机制。 目录 一、什么是数据结构 二、时间复杂度&#xff0c;空间复杂度 2.1 时间复杂度&#xff0c;空间…

传输层7——TCP拥塞控制(重点!!!)

目录 一、认识拥塞控制 1、什么叫做拥塞&#xff1f; 2、拥塞的特点 3、流量控制 VS 拥塞控制 二、TCP如何防止拥塞&#xff1f; 1、慢开始 2、拥塞避免 3、3重复确认 和 快重传算法 4、快恢复算法 5、总结 三、主动队列管理AQM 1、技术背景 2、AQM思 想和实现策略…

[64]最小路径和⭐

[64]最小路径和⭐ 题目描述 给定一个包含非负整数的 m x n 网格 grid &#xff0c;请找出一条从左上角到右下角的路径&#xff0c;使得路径上的数字总和为最小。 **说明&#xff1a;**每次只能向下或者向右移动一步。 示例输入 示例 1&#xff1a; 输入&#xff1a;grid …

AI技术架构:从基础设施到应用

人工智能&#xff08;AI&#xff09;的发展&#xff0c;正以前所未有的速度重塑我们的世界。了解AI技术架构&#xff0c;不仅能帮助我们看懂 AI 的底层逻辑&#xff0c;还能掌握其对各行业变革的潜力与方向。 一、基础设施层&#xff1a;AI 技术的坚实地基 基础设施层是 AI 技…

每日计划-1213

1. 完成 SQL2 查询多列 https://www.nowcoder.com/exam/oj?page1tabSQL%E7%AF%87topicId199 2. 八股部分 1) C 中面向对象编程如何实现数据隐藏&#xff1f; 在c中&#xff0c;可以将数据成员声明为私有或受保护&#xff0c;并提供公有的成员函数来访问和修改这些数据成员&am…

【ADS射频电路设计教程】1. ADS基本操作

下面介绍ADS中主要仿真器的使用 1. 直流仿真 直流仿真器在控制面板的simulator-dc 直流仿真器 但是ADS自带有很多仿真器&#xff0c;可以直接来调用 选用晶体管电流扫描的模板 就可以输出模板 然后调入晶体管模型 然后要设置扫描的电压&#xff0c;选择dc仿真器对vds进行扫描…

EasyGBS点对点穿透P2P远程访问技术在安防视频监控中的应用

随着信息技术的快速发展&#xff0c;安防视频监控系统在公共安全领域的应用变得越来越广泛。传统的视频监控系统多依赖于中心服务器进行视频流的集中处理和分发&#xff0c;这不仅增加了网络带宽的负担&#xff0c;还可能成为系统性能瓶颈。为了解决这些问题&#xff0c;P2P&am…

CTFHub 命令注入-综合练习(学习记录)

综合过滤练习 命令分隔符的绕过姿势 ; %0a %0d & 那我们使用%0a试试&#xff0c;发现ls命令被成功执行 /?ip127.0.0.1%0als 发现一个名为flag_is_here的文件夹和index.php的文件&#xff0c;那么我们还是使用cd命令进入到文件夹下 http://challenge-438c1c1fb670566b.sa…

美团2024年秋招第一场笔试【前端移动端】

美团2024年秋招第一场笔试【前端&移动端】 2024/12/12 1.在一个长度为28的数组中删除第5个元素时&#xff08;元素序号&#xff1a;1~28&#xff09;&#xff0c;需要向前移动&#xff08;23&#xff09;个元素。 2.如下图一个树型结构&#xff0c;其结点E在树的中序遍历…