Next.js动态路由如何使用

官方解释

Next.js 允许你创建具有 动态路由 的页面。例如,你可以创建一个名为 pages/posts/[id].js 的文件用以展示以 id 标识的单篇博客文章。当你访问 posts/1 路径时将展示 id: 1 的博客文章。

代码

这里先用一个写好的实例代码来展示

javascript 复制代码
import React from 'react';

// 步骤1
export async function getStaticPaths() {
    // 模拟调用外部 API 获取博文列表
    const posts = [
        { id: 1 },
        { id: 2 },
        { id: 3 }
    ];

    // 根据博文列表生成所有需要预渲染的路径
    const paths = posts.map((post) => ({
        params: { id: post.id.toString() }
    }));

    // 返回需要预渲染的路径和fallback配置
    return { paths, fallback: false };
}

// 步骤2
export async function getStaticProps({ params }) {
    // 使用params中的id获取特定博文数据,这里只是模拟数据
    const postData = { id: params.id, title: 'Post Title', content: 'Post Content' };

    return {
        props: {
            postData
        }
    };
}

// 渲染页面
function Post({ postData }) {
    return (
        <div>
            <h1>{postData.title}</h1>
            <h1>{postData.id}</h1>
            <p>{postData.content}</p>
        </div>
    );
}

export default Post;

我们依次访问一下路径
http://localhost:3000/post/1

http://localhost:3000/post/2

http://localhost:3000/post/3

不难发现每次渲染的都是不同页面,这就是动态路由,能够根据你传来的数字显示不同的页面

他和传统的动态路由不同,next.js的实现方式很简单:

下面是我这个页面的文件目录

可以看见我的文件名字是[id].js,这个是next.js规定的

getStaticPaths 是给我们定义一个路径,也就是当我们访问http://localhost:3000/post/1的时候,文件中没有这个名字,但是也能访问的到

getStaticProps是用来给我们的页面传参的

function Post({ postData })中的postData是接收getStaticProps传来的参数

其余的都在上面的代码中,看一下很容易就能够理解运用起来

相关推荐
爱滑雪的码农1 小时前
详细说说React大型项目结构以及日常开发核心语法
前端·javascript·react.js
七牛开发者1 小时前
HTML is the new Markdown:来自 Claude Code 团队的实践
前端·人工智能·语言模型·html
@大迁世界2 小时前
43.HTML 事件处理和 React 事件处理有什么区别?
前端·javascript·react.js·html·ecmascript
CloneCello2 小时前
AI时代程序员认知调整指南
前端
代钦塔拉2 小时前
Qt4 vs Qt5 带参数信号槽的连接方式详解
开发语言·数据库·qt
ZC跨境爬虫3 小时前
跟着 MDN 学 HTML day_38:(DocumentFragment 文档片段接口详解)
前端·javascript·ui·html·音视频
@大迁世界4 小时前
41.ShadCN 是什么?它如何和 Tailwind CSS 集成,从而更容易构建可访问且可自定义的 React 组件?
前端·javascript·css·react.js·前端框架
千叶风行4 小时前
Text-to-SQL 技术设计与注意事项
前端·人工智能·后端
软件开发技术深度爱好者4 小时前
HTML5+JavaScript读取DOCX 文档完整内容
前端·html5
InfinteJustice4 小时前
踩坑分享C 语言文件操作全攻略:从基础读写到随机访问与缓冲区原理
c语言·开发语言·microsoft