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

Next.js- App Router 概览

#题引:我认为跟着官方文档学习不会走歪路

一:App Router与Page Router

在 v13 版本中,Next.js 引入了一个基于 React 服务器组件 构建的新的 App Router,而在这之前,Next.js 使用的是Page Router。

  1. 目录结构
    pages 目录:使用传统的文件系统路由,每个文件对应一个路由。页面组件通常是 React 组件。
    app 目录:引入了全新的路由机制,支持更灵活的布局和嵌套路由。可以使用服务端组件、客户端组件和布局。
  2. 服务端组件
    pages 目录:不支持服务端组件,只能使用客户端组件和传统的数据获取方法(如 getServerSideProps 和 getStaticProps)。
    app 目录:原生支持服务端组件,可以直接在组件中获取数据,简化了数据获取流程。
  3. 数据获取
    pages 目录:通过 getStaticProps、getServerSideProps 和 getStaticPaths 来处理数据获取。
    app 目录:可以使用 React 的 async 组件,直接在组件中获取数据,简化了数据处理。
  4. 布局
    pages 目录:布局通常需要在每个页面中显式定义。
    app 目录:支持嵌套布局,可以在不同层级的目录中定义布局,提升了组件复用性。
  5. 文件名约定
    pages 目录:文件名直接对应路由。
    app 目录:除了文件名外,还可以使用 layout.js、page.js 等特殊文件名来定义布局和页面。
  6. 静态和动态路由
    pages 目录:静态和动态路由都可以通过文件名实现,但动态路由的处理相对复杂。
    app 目录:动态路由和静态路由处理更加灵活,可以使用文件夹和文件组合来实现。
    在这里插入图片描述
    app 目录与 pages 目录一起工作时,App Router 优先级高于 Pages Router,这使你可以将应用程序的某些路由选择使用新行为,同时保持其他路由在 pages 目录中使用以前的行为。

二:App Router的一些规定

文件与路由的映射

在 app 目录中,每个文件和文件夹都会自动映射为一个路由。例如,app/dashboard/settings文件会对应 /dashboard/settings路由, 要创建嵌套路由,可以将文件夹嵌套在一起。
在这里插入图片描述

特殊文件

使用特殊的 page.js 文件(特殊文件可以使用 .js、.jsx、.ts 或 .tsx 文件扩展名) 可以使路由段公开访问,在下面这张图中,在这个例子中,/dashboard/analytics URL 路径是不可公开访问的,因为它没有对应的 page.js 文件。这个文件夹可以用来存储组件、样式表、图片或其他相关文件。
在这里插入图片描述
所以,路由是一个从根文件夹到包含 page.js 文件的最终叶子文件夹的嵌套文件夹的单一路径。

文件约定:Next.js 提供了一组特殊文件,用于在嵌套路由中创建具有特定行为的 UI
在这里插入图片描述

组件层次结构

使用特殊文件约定来为每个路由段(路由中的每个文件夹代表一个路由段,如/dashboard/settings中的dashboard和settings)创建 UI.

路由段中特殊文件中定义的 React 组件按特定层次结构渲染

在这里插入图片描述
在嵌套路由中,段的组件将嵌套在其父段的组件内部
在这里插入图片描述

http://www.lryc.cn/news/489958.html

相关文章:

  • python oa服务器巡检报告脚本的重构和修改(适应数盾OTP)有空再去改
  • 【工控】线扫相机小结 第四篇
  • 亲测解决Unpack operator in subscript requires Python 3.11 or newer
  • 数据结构 ——— 堆排序算法的实现
  • On-Chip-Network之Topology
  • 2024年11月21日Github流行趋势
  • 第三十八章 IOT 通信协议MQTT协议实现的中间件EMQXDocker安装与验证指南
  • Flume日志采集系统的部署,实现flume负载均衡,flume故障恢复
  • CodiMD导出pdf失败或无中文
  • 数字图像处理(2):Verilog基础语法
  • Kafka 工作流程解析:从 Broker 工作原理、节点的服役、退役、副本的生成到数据存储与读写优化
  • 爬虫重定向问题解决
  • Java技术复习提升 10异常
  • 真题-桂城2022年五年级
  • android 使用MediaPlayer实现音乐播放--权限请求
  • Web开发:ORM框架之使用Freesql的DbFrist封装常见功能
  • 【多线程-第一天-多线程的执行原理-多线程的优缺点-主线程 Objective-C语言】
  • SQL基础语法介绍-基于MySQL
  • 一分钟学习数据安全——数据安全风险的系统化应对思路
  • 端口port常识
  • 【Oracle实战】文章导读
  • “人工智能+高职”:VR虚拟仿真实训室的发展前景
  • c语言学习27宏定义条件编译
  • 理论结合实践:用Umami构建网站分析系统
  • Unreal从入门到精通之如何绘制用于VR的3DUI交互的手柄射线
  • 移动充储机器人“小奥”的多场景应用(上)
  • 已解决wordpress提示正在执行例行维护,请一分钟后回来
  • DDR3脚位解析,class分类
  • 【深度学习|目标跟踪】DeepSort 详解
  • 快速图像识别:落叶植物叶片分类