nextjs-创建layouts共用UI和独立pages页面

原文链接:https://nextjs.org/learn/dashboard-app/creating-layouts-and-pages

到目前为止,您的应用程序只有一个主页。让我们学习如何使用布局页面创建更多路由。

本章目标

  • 使用文件系统路由创建 dashboard路由。
  • 了解创建新路由时文件夹和文件的作用。
  • 创建可在多个dashboard页面之间共享的嵌套布局。
  • 了解主机代管、部分渲染和根布局是什么。

嵌套路由

Next.js使用文件系统路由,其中文件夹用于创建嵌套路由。每个文件夹代表一个映射到URL段的路由段。
image.png
您可以使用layout.tsx和page.tsx文件为每条路线创建单独的UI。
page.tsx是一个特殊的Next.js文件,用于导出React组件,它是访问路由所必需的。
在您的应用程序中,您已经有一个页面文件:/app/page.tsx 这是与根路由/关联的主页。
要创建嵌套路由,可以将文件夹嵌套在一起,并在其中添加page.tsx文件。例如
image.png
/app/dashboard/page.tsx与/dashboard路径相关联。让我们创建页面,看看它是如何工作的!

创建dashboard页面

在/app内创建一个名为dashboard的新文件夹。然后,在dashboard文件夹中创建一个新的page.tsx文件,其中包含以下内容:

export default function Page() {
  return <p>Dashboard Page</p>;
}

现在,确保开发服务器正在运行并访问http://localhost:3000/dashboard.您应该看到“Dashboard Page”文本。
这就是在Next.js中创建不同页面的方法:使用文件夹创建一个新的路由,并在其中添加一个页面文件。
通过为页面文件指定一个特殊名称,Next.js允许您对UI组件进行并置,test文件和其他与路由相关的代码。
只有页面文件中的内容才能公开访问。例如,/ui和/lib文件夹与路由一起位于/app文件夹中。

练习:创建仪表板页面

让我们练习创建更多路由。在您的面板中,再创建两个页面:

  • Customers Page:该页面应可在上访问http://localhost:3000/dashboard/customers.目前,它应该返回一个<p>Customers Page</p>元素。
  • Invoices Page:发票页面应可访问http://localhost:3000/dashboard/invoices.现在,还返回<p>Invoices Page</p>元素。

花点时间处理此练习,准备好后,展开下面的切换以获取解决方案:
您应该具有以下文件夹结构:
image.png
Customers Page:

export default function Page() {
  return <p>Customers Page</p>;
}

Invoices Page:

export default function Page() {
  return <p>Invoices Page</p>;
}

创建dashboard layout页面

dashboard具有某种可在多个页面之间共享的导航功能。在Next.js中,您可以使用一个特殊的layout.tsx文件来创建在多个页面之间共享的UI。让我们为dashboard页面创建一个layout布局!
/dashboard文件夹中,添加一个名为layout.tsx的新文件,并粘贴以下代码:

import SideNav from '@/app/ui/dashboard/sidenav';
 
export default function Layout({ children }: { children: React.ReactNode }) {
  return (
    <div className="flex h-screen flex-col md:flex-row md:overflow-hidden">
      <div className="w-full flex-none md:w-64">
        <SideNav />
      </div>
      <div className="flex-grow p-6 md:overflow-y-auto md:p-12">{children}</div>
    </div>
  );
}

这段代码中发生了一些事情,所以让我们对其进行分解:
首先,将<SideNav/>组件导入到布局中。导入到此文件中,任何组件都将成为布局的一部分。
<Layout/>组件接收一个children props。此子项可以是页面,也可以是其他布局。在您的情况下,/dashboard内的页面将自动嵌套在<Layout/>中,如下所示:
image.png
通过保存您的更改并检查您的localhost来检查一切是否正常工作。您应该看到以下内容:
image.png
在Next.js中使用布局的一个好处是,在导航方面,只有页面组件会更新,而布局不会重新渲染。这称为部分渲染
image.png

根layout

在第3章中,您将Inter字体导入到另一个布局中:/app/layout.tsx。作为提醒:

import '@/app/ui/global.css';
import { inter } from '@/app/ui/fonts';
 
export default function RootLayout({
  children,
}: {
  children: React.ReactNode;
}) {
  return (
    <html lang="en">
      <body className={`${inter.className} antialiased`}>{children}</body>
    </html>
  );
}

这被称为根布局,是必需的。
任何UI组件添加到根布局后,都将在应用程序的所有页面中共享。
您可以使用根布局来修改和标记,并添加元数据(您将在后面的章节中了解有关 meta 元数据的更多信息)。
由于您刚刚创建的新布局(/app/dashboard/layout.tsx)对于仪表板页面是唯一的,因此您不需要向上面的根布局添加任何UI。

  • 34
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
vite-plugin-pages是一个用于Vite项目的插件,它可以帮助我们更高效地开发。通过使用vite-plugin-pages,我们只需要在指定的目录下编写对应的页面组件,插件会自动根据这些组件生成路由配置。默认情况下,插件使用的页面文件夹是"pages",并且默认指定的页面是"index.vue"。当然,你也可以根据自己的习惯进行配置,比如将页面文件夹改为"views"。在使用vite-plugin-pages之前,需要先安装vue-router,因为插件是基于vue-router的。然后,在指定的页面文件夹下创建一个"index.vue"文件,这样插件才能正确地生成路由配置。通过这种方式,我们可以更加方便地管理和使用路由,提高开发效率。 #### 引用[.reference_title] - *1* *3* [vite(vue-ts)项目vite-plugin-pages,vite-plugin-vue-layouts,vite-plugin-windicss等插件引入方式](https://blog.csdn.net/Junikusa/article/details/124179542)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [vite-plugin-pages](https://blog.csdn.net/MCCLS/article/details/131661419)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值