- vừa được xem lúc

Hướng dẫn xây dựng blog cá nhân với NextJs và Notion

0 0 11

Người đăng: Kha Leo

Theo Viblo Asia

Trong bài viết này chúng ta sẽ cùng xây dựng một blog nhanh nhất cho riêng mình với NextJs và Notion

I. Prerequisites

Về mặt ý tưởng, chúng ta sẽ sử dụng notion như một CMS giúp quản lý thông tin bài viết và NextJs để hiển thị thông tin đó cho user cũng như tận dụng SSR cho việc cải thiện SEO, security...

  • Kiến thức về NextJs
  • Tài khoản Notion cá nhân

II. Tạo database và access token ở Notion

  1. Chọn một page ở Notion dùng để lưu trữ database
  2. Thêm phần tử mới và chọn Database - Full page
  3. Tạo các field cho database, bao gồm loại và mục đích như sau (các field dùng cho việc demo, các bạn có thể thay đổi sau):
  • Title: field được tạo sẵn, mặc định là Name, các bạn chuyển thành Title nhé
  • Tags (Multi-select): thẻ chủ đề
  • Description (Text): Mô tả ngắn cho bài viết
  • PresentativeMedia (Files & media): Để lưu ảnh đại diện cho bài viết
  • Slug (Text): dùng làm đường dẫn cho bài viết
  • Status (Status): trạng thái bài viết, bao gồm Draft, Published
  1. Tiếp theo, các bạn truy cập notion-integration để tạo secret token liên kết với Notion cá nhân mình dùng để tạo database phía trên nhé. Lưu ý chỉ cần chọn quyền đọc: Read content, như hình bên dưới:
  2. Sau khi tạo notion-integration, bước tiếp theo cần cho phép integration này có thể truy cập database. Ở mục Connect to, chọn integration vừa tạo (mình vừa tạo for-show-sample), như hình dưới:

III. Tạo database mẫu

  • Dựa vào cấu trúc database đã tạo, chúng ta sẽ tạo một vài record mẫu như sau. Lưu ý, status của các bài viết chuyển về Published

IV. Sử dụng notion-nextjs-mini-kit

  1. Các bạn làm theo hướng dẫn để clone và run source NextJs ở máy nhé: tại đây
  2. Theo hướng dẫn cài đặt, chúng ta sẽ cần thay thế 2 biến môi trường
NOTION_TOKEN=
NOTION_DATABASE_ID=

Trong đó:

  • Notion token là token đã được tạo ra từ Bước II
  • Để lấy database id từ database chúng ta đã tạo, chỉ cần mở chính trang database bằng browser và copy chuỗi như hình:
  1. Chạy ứng dụng NextJs bên trên và chúng ta sẽ thấy được kết quả như sau

V. Tạo nội dung cho trang

  1. Tạo nội dung cho các trang dựa trên dữ liệu đã tạo ở database trước đó
  2. Publish bài viết (chọn share -> publish)
  3. Quay lại trang web của chúng ta, click chọn 1 trong các bài trước đó để xem thành quả 🎉

VI. Tổng kết

References

Trên đây mình đã hướng dẫn các bạn tạo nhanh một blog cá nhân bằng việc sử dụng NextJs và Notion như một database. Nếu có bất cứ câu hỏi hoặc đóng góp nào, các bạn để lại phía dưới bình luận cho mình biết nhé. Cảm ơn tất cả mọi người

Happy coding! 🙌🏻

Bình luận

Bài viết tương tự

- vừa được xem lúc

Viết một chiếc app quản lý Hạn sử dụng của thực phẩm

Mở đầu. Tôi là 1 kỹ sư công nghệ thông tin mới ra trường. Trong thời gian học Đại học, từ năm 1 tới năm 4, tôi đi làm thêm tại TSUTAYA (chuỗi cửa hàng bán sách, video...v.v nổi tiếng bên Nhật). Về chiếc App tôi đã phát triển. App tôi phát triển là Web App giúp quản lý hạn sử dụng của đồ ăn.

0 0 52

- vừa được xem lúc

Routing trong Next.js

Trước đó bạn có thể đang tò mò về Next.js, vào đây luôn bạn ơi. (go). .

1 0 56

- vừa được xem lúc

Cài đặt chuyển đổi ngôn ngữ trong một project NextJS

Ở phiên bản Nextjs Version 10 mới đây, việc sử dụng i18n đã trở nên dễ dàng hơn qua tính nâng cao là Internationalized Routing. Cài đặt cấu hình cơ bản. Tại file next.config.

0 0 73

- vừa được xem lúc

Cấu hình eslint airbnb, prettier cho dự next.js sử dụng typescript

Chào mọi, mình đã quay lại đây. Hôm nay mình sẽ đem đến một chủ đề linter cụ thể cấu hình eslint cho dự án next.

0 0 195

- vừa được xem lúc

Handling custom page navigation on Next.js

Last month we discussed about different kind of routing on Next.js. Here's a short example of creating a component that moves the user to next page. import { useRouter } from 'next/router'.

0 0 87

- vừa được xem lúc

Next Image một feature, một nâng cấp tuyệt vời version nextjs 10

NextJS đã cho ra mắt version 10 cách đây 2 tháng với hơn 20 fearture nâng cấp đáng giá. Chúng ta có thể kể ra những features nổi bật như. . Next/Image: với khẳ năng render image cho các kích thước màn hình tương ứng.

0 0 62