Building a personal blog with Next.js and Notion

In this article, we will together build the fastest blog for yourself with Next.js and Notion.

I. Prerequisites

Notion is certainly no stranger to everyone. It is an AI-powered workspace that helps users easily plan, take notes, and integra…


This content originally appeared on DEV Community and was authored by Le Xuan Kha (Leo)

In this article, we will together build the fastest blog for yourself with Next.js and Notion.

I. Prerequisites

Notion is certainly no stranger to everyone. It is an AI-powered workspace that helps users easily plan, take notes, and integrate with many other applications, making it very convenient.

In terms of the idea, we will use Notion as a CMS to manage post information, and Next.js to display that information for users while leveraging SSR to improve SEO and security.

  • Knowledge of Next.js
  • Personal Notion account

II. Create a database and access token in Notion

  1. Select a page in Notion to store the database.
  2. Add a new element and choose Database - Full page: Add a new element and choose Database
  3. Create the following fields for the database, specifying their type and purpose as follows (these fields are for demo purposes, you can modify them later):

    • Title: Already created as Name, change it to Title
    • Tags (Multi-select): Topic tags
    • Description (Text): Brief description of the post
    • PresentativeMedia (Files & media): To store the featured image for the post
    • Slug (Text): Used as the post's URL
    • Status (Status): Post status, including Draft, Published Create fields for the database
  4. Next, you can access notion-integration to generate a secret token linked to your personal Notion account, which will be used to create the above database. Remember to select only the Read permission: Read content, as shown in the image below:
    notion-integration

  5. After creating the notion-integration, the next step is to allow this integration to access the database. In the Connect to section, choose the integration you just created (I just created for-show-sample), as shown in the image below:
    allow this integration to access the database.

III. Create sample records in database

Based on the created database structure, we will create some sample records as follows. Note that the status of the posts should be changed to Published.

Create sample records

IV. Using notion-nextjs-mini-kit

  1. You can follow the instructions to clone and run the NextJs source code on your machine here.

  2. As per the installation instructions, you will need to replace 2 environment variables.
    NOTION_TOKEN=
    NOTION_DATABASE_ID=

    With:

    • The Notion token is the token generated from Step II.
    • To get the database ID from the database we created, simply open the database page in the browser and copy the string as shown in the image.
  3. Run the NextJs application above and you will see the results as follows

Result

V. Create content for the page

  1. Create content for the pages based on the data created in the previous database.
    Create content for the page

  2. Publish the posts (select share -> publish)
    Publish the posts

  3. Return to our website, click on one of the previous posts to see the results 🎉
    see the results

VI. Conclusion

References

  • notion-nextjs-mini-kit: github.com/khaaleoo/notion-nextjs-mini-kit

On this guide, I have shown you how to quickly create a personal blog using NextJs and Notion as a database. If you have any questions or contributions, please leave a comment below. Thank you everyone.

Happy coding! 🙌🏻


This content originally appeared on DEV Community and was authored by Le Xuan Kha (Leo)


Print Share Comment Cite Upload Translate Updates
APA

Le Xuan Kha (Leo) | Sciencx (2024-06-21T07:18:11+00:00) Building a personal blog with Next.js and Notion. Retrieved from https://www.scien.cx/2024/06/21/building-a-personal-blog-with-next-js-and-notion/

MLA
" » Building a personal blog with Next.js and Notion." Le Xuan Kha (Leo) | Sciencx - Friday June 21, 2024, https://www.scien.cx/2024/06/21/building-a-personal-blog-with-next-js-and-notion/
HARVARD
Le Xuan Kha (Leo) | Sciencx Friday June 21, 2024 » Building a personal blog with Next.js and Notion., viewed ,<https://www.scien.cx/2024/06/21/building-a-personal-blog-with-next-js-and-notion/>
VANCOUVER
Le Xuan Kha (Leo) | Sciencx - » Building a personal blog with Next.js and Notion. [Internet]. [Accessed ]. Available from: https://www.scien.cx/2024/06/21/building-a-personal-blog-with-next-js-and-notion/
CHICAGO
" » Building a personal blog with Next.js and Notion." Le Xuan Kha (Leo) | Sciencx - Accessed . https://www.scien.cx/2024/06/21/building-a-personal-blog-with-next-js-and-notion/
IEEE
" » Building a personal blog with Next.js and Notion." Le Xuan Kha (Leo) | Sciencx [Online]. Available: https://www.scien.cx/2024/06/21/building-a-personal-blog-with-next-js-and-notion/. [Accessed: ]
rf:citation
» Building a personal blog with Next.js and Notion | Le Xuan Kha (Leo) | Sciencx | https://www.scien.cx/2024/06/21/building-a-personal-blog-with-next-js-and-notion/ |

Please log in to upload a file.




There are no updates yet.
Click the Upload button above to add an update.

You must be logged in to translate posts. Please log in or register.