Nextjs 动态路由获取参数

目录

一、创建page目录下的路由文件

二、通过useRouter来获取动态参数


先看官方文档:Routing: Dynamic Routes | Next.js

使用Nextjs13版本参考官方文档后实现仍有问题,网上的材料大多和官网一致,经过测试后,我找到了这个解决方案:

一、创建page目录下的路由文件

这一步与官方文档描述一致

二、通过useRouter来获取动态参数

import React from "react";
import {useRouter} from "next/router";

export default function People() {
    const route = useRouter();
    const query: { username: string } = route.query as { username: string }
    console.log(query.username)

    return <div>My Page</div>
}

useRouter()有个query属性可以获取到动态路径的参数,这样问题就解决了。

  • 10
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Next.js 中,可以使用 `getServerSideProps` 函数来处理动态路由。在该函数中,可以通过 `res` 对象向客户端发送文件。 以下是一个示例代码,用于在 Next.js 中处理动态路由并提供文件下载服务: ```jsx import fs from 'fs'; export async function getServerSideProps({ params, res }) { const { fileId } = params; const filePath = `./public/files/${fileId}.pdf`; // 文件路径 // 检查文件是否存在 if (!fs.existsSync(filePath)) { res.statusCode = 404; res.end('File not found'); return { props: {} }; } // 设置响应头 res.setHeader('Content-Disposition', `attachment; filename=${fileId}.pdf`); res.setHeader('Content-Type', 'application/pdf'); // 读取文件并发送给客户端 const fileContent = fs.readFileSync(filePath); res.send(fileContent); return { props: {} }; } function FileDownload({}) { return <div>Downloading file...</div>; } export default FileDownload; ``` 在上述代码中,我们首先检查文件是否存在,如果不存在则返回 404 错误。然后设置响应头,告诉客户端将文件作为附件下载,并设置正确的 MIME 类型。最后,我们读取文件内容并将其发送给客户端。 请注意,文件路径应该是相对于 Next.js 项目根目录的。在上述示例代码中,我们假设文件存储在 `public/files` 目录中,并且文件名是动态路由参数 `fileId` 的值加上 `.pdf` 后缀。因此,如果用户访问 `/files/123.pdf`,我们将读取 `./public/files/123.pdf` 文件并返回给客户端。 希望对你有所帮助!

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值