首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

使用 NextJS 和 TailwindCSS 重构我的博客

(slug=>({ params:slug })), fallback: true //or false }; } 当网站构建后,新写的文章也需要生成静态页面,这时就可以将...{ // 在打包时值生成 `/posts/1` 和 `/posts/2` 的静态页面 paths: [{ params: { id: '1' } }, { params: { id:...获取文章详情 export async function getStaticProps({ params }) { // 如果页面的路由是 /posts/1, 这 params.id 的值就是1...Prisma 支持 Mysql、Postgresql 和 Sqlite, 访问官网我们可以很容易的上手,也可以快速的从老项目接入 虽然 Prisma 和 TypeORM 解决了类似的问题,但它们的工作方式却大相径庭...喜欢的同学可以 fork 一下,免费部署到 Heroku 中,Heroku 支持免费的 Postgresql 数据库,也可以将程序部署到 https://vercel.app/ (国内比较快,不支持数据库

2.4K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    从 Next.js 看企业级框架的 SSR 支持

    ) pages/post/[...all].js → /post/* (/post/2020/id/title) 路径中变化的参数通过getStaticPaths来填充: // pages/posts.../[id].js export async function getStaticPaths() { return { // 必须叫paths,值必须是数组 paths: [{...id: 'pre-rendering' } }], fallback: false } } 进一步传递给getStaticProps按参数获取数据,并渲染页面...只在服务端执行(根本不会进入客户端 bundle),返回的静态数据会传递给页面组件(上例中的Home)。...,普通组件不允许,所以要求将整页依赖的所有数据都组织到一处 至于渲染生成 HTML 的部分,借助React 提供的 SSR API即可完成 至此,只要是依赖数据有办法提前获取到的页面,理论上都可以编译生成静态

    3.9K11

    Next.js进阶:静态生成、服务器端渲染与SEO优化

    在本文中,我将深入探讨这些核心特性的工作原理、应用场景及最佳实践,并通过代码示例演示如何在实际项目中高效利用Next.js实现高性能、高SEO友好的应用。...使用getStaticPaths预定义动态路由对于动态路由(如pages/posts/[slug].js),需要使用getStaticPaths指定预渲染的路径列表。...};};export const getStaticProps = async (context) => { const post = await fetchPostBySlug(context.params.slug...id; // 从请求上下文中获取当前用户ID const personalizedData = await fetchPersonalizedData(currentUserId); // 获取实时数据...作为博主,我将持续探索并分享Next.js的进阶技巧与最佳实践,帮助开发者们充分发挥其潜力,打造卓越的用户体验与商业成果。

    1.1K10

    偷师 Next.js:我学到的 6 个设计技巧

    写在前面 最近在研究 SSR 的过程中,也对 Next.js 有了更多的认识: 全面介绍:《从 Next.js 看企业级框架的 SSR 支持》 核心特性:《鱼和熊掌兼得:Next.js 混合渲染》 设计技巧...│ ├── photo │ │ ├── [id].tsx │ │ ├── download │ │ │ └── [id].tsx │ │ └── index.tsx...redux 设计出来,读起来根本停不下来 Electron Demo App:交互式文档,准确地说是带完整文档的 Demo,在体验 Demo App 的同时了解相关特性用法,是比React 在做中学更偷懒的办法了...,最佳实践本就应该是默认提供的,将新出现的最佳实践不断地下沉到环境层,就像 npm package、ES Module、Babel 等,如今的前端开发者已经几乎不需要关心这些曾经的最佳实践 仅从框架设计角度而言...,将有趣的知识传递更远~

    2.4K10

    Next.js 简明教程

    原因是,一个正常的同构需求,我们需要: 前端组件渲染为HTML字符串,流 服务端,客户端资源的加载不同处理,(首屏不一定全部加载完所有js……) 服务端,客户端的状态数据的传递 打包工具链 性能优化 …...`和`getStaticPaths`(SSG)构建时请求数据 所谓的SSG也就是静态站点生成,类似像hexo或者gatsbyjs都是在build阶段将页面构建成静态的html文件,这样线上直接访问HTML...Next 在9.3中更近了一步,引入了getStaticProps和getStaticPaths方法来让开发者指定哪些页面可以做SSG优化。...使用getStaticProps方法在build阶段返回页面所需的数据。 如果是动态路由的页面,使用getStaticPaths方法来返回所有的路由参数,以及是否需要回落机制。...静态缓存目前没办法很灵活的更新!!,例如博客内容在build或者fallback生效之后发生更改,目前没办法很方便的替换缓存。

    3K20

    React 必学SSR框架——next.js

    启动服务器后,Next.js 将: 为您填充 tsconfig.json 文件。您也可以自定义此文件。...和getStaticPaths(SSG)构建时请求数据 所谓的SSG也就是静态站点生成,类似像hexo或者gatsbyjs都是在build阶段将页面构建成静态的html文件,这样线上直接访问HTML文件...Next 在9.3中更近了一步,引入了getStaticProps和getStaticPaths方法来让开发者指定哪些页面可以做SSG优化。...使用getStaticProps方法在build阶段返回页面所需的数据。 如果是动态路由的页面,使用getStaticPaths方法来返回所有的路由参数,以及是否需要回落机制。...静态缓存目前没办法很灵活的更新!!,例如博客内容在build或者fallback生效之后发生更改,目前没办法很方便的替换缓存。

    7.7K20

    动手练一练,使用 React 和 Next.js 做一个简单的博客网站(中)

    pages/articles/[id].js 这个文件里实现Next.js 特有的 getStaticPaths() 函数功能(Static Generation),在项目构建时生成指定的路由路径,比如这个案例将...articles 目录下的 MD 文档返回如下的数组格式,id 将匹配 pages/articles/[id].js 对应的 [id] 参数生成动态路由: [   { params: { id: "article...({ params }),在项目构建时调用这个函数(Static Generation),通过 id 参数调用 lib/posts-md.js 文件中 getFileData() 定义的方法,将 MD...  }; } 6、拿到数据后,我们需要填充到组件的模板里,以更友好的形式展现,我们在 pages/articles/[id].js 里编写JSX的相关代码,将文章内容嵌套在上节组件模板内,示例代码如下...在下篇文章里,我们为博客网站添加暗黑模式,基于接口数据渲染内容(服务端渲染),及如何编译项目将博客网站部署到 Node.js 服务器上或纯静态化部署,最后会提供完整的项目源码,敬请期待...

    1.8K11

    动手练一练,使用 React 和 Next.js 做一个简单的博客网站(中)

    pages/articles/[id].js 这个文件里实现Next.js 特有的 getStaticPaths() 函数功能(Static Generation),在项目构建时生成指定的路由路径,比如这个案例将...articles 目录下的 MD 文档返回如下的数组格式,id 将匹配 pages/articles/[id].js 对应的 [id] 参数生成动态路由: [ { params: { id: "article...({ params }),在项目构建时调用这个函数(Static Generation),通过 id 参数调用 lib/posts-md.js 文件中 getFileData() 定义的方法,将 MD...}; } 6、拿到数据后,我们需要填充到组件的模板里,以更友好的形式展现,我们在 pages/articles/[id].js 里编写JSX的相关代码,将文章内容嵌套在上节组件模板内,示例代码如下...在下篇文章里,我们为博客网站添加暗黑模式,基于接口数据渲染内容(服务端渲染),及如何编译项目将博客网站部署到 Node.js 服务器上或纯静态化部署,最后会提供完整的项目源码,敬请期待...

    92530
    领券