type
status
date
slug
summary
tags
category
icon
password
URL
url
本文介绍了如何使用Notion和Next.js构建一个博客。作者分享了他们使用Markdown的经验,以及为何选择Notion作为CMS。通过react-notion和notion-api-worker,作者展示了如何将Notion页面渲染为React组件,并使用Next.js创建静态博客页面。文章还介绍了如何集成Splitbee.io进行博客分析。
从网站内容看来,不是免费的,pass(hah)
关键功能
- 选择Notion作为CMS: 作者因不满Markdown的编辑功能,决定使用Notion的丰富内容编辑功能来构建博客。
- react-notion的创建: 基于Vercel的Notion博客项目和chorale.app,作者开发了react-notion,一个可以渲染Notion内容的开源React渲染器。
- notion-api-worker: 为了获取Notion页面的blockMap,作者创建了一个基于Cloudflare Workers的无服务器包装器,以提供快速响应。
- Next.js项目设置: 使用Vercel提供的指南设置Next.js项目,并集成react-notion。
- 博客概览页面实现: 使用getStaticProps获取所有博客帖子,并在主页上展示链接列表。
- 博客文章页面实现: 通过slug获取特定博客文章的内容,并使用NotionRenderer渲染。
- Next.js路由和样式: 实现getStaticPaths以支持基于slug的路由,并引入必要的CSS样式。
- Splitbee集成: 作者介绍了Splitbee.io的分析工具,并提供了集成到博客的步骤。
- 获取Splitbee: 提供了注册Splitbee的链接,并展示了如何在博客中添加分析脚本。
- 项目代码: 网站最后提供了GitHub上的完整代码链接,供读者参考。
- 作者:notion2go
- 链接:https://notion2go.com/article/react-notion-blog
- 声明:本文采用 CC BY-NC-SA 4.0 许可协议,转载请注明出处。