DEV Community

Cover image for Building a personal blog with Next.js and Notion
Le Xuan Kha (Leo)
Le Xuan Kha (Leo)

Posted on • Edited on

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 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

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! 🙌🏻

Top comments (7)

Collapse
 
viktorngo profile image
Ngo Viktor

Wonderful bro, it's a great ideal

Collapse
 
khaleo profile image
Le Xuan Kha (Leo)

thank you

Collapse
 
fioenix profile image
Fioenix

It's the first time I read a great article 😎 Love you 😘

Collapse
 
khaleo profile image
Le Xuan Kha (Leo)

love you for your support 😘

Collapse
 
loenchay profile image
Duy Nguyễn

Love that, keep it up man

Collapse
 
khaleo profile image
Le Xuan Kha (Leo)

Thank you 🥳

Collapse
 
um1chc5 profile image
Vũ An

Hay bạn ơi, tks so much!