Views: 830
Mục tiêu
Setup thành công một demo nhỏ với NextJS Framework; kết hợp với TailwindCSS (utility-first CSS framework); tích hợp module cần thiết cho Frontend development (SASS/SCSS loader, BrowserSync…) giúp việc code frontend nhanh hơn; sau cùng, deploy production bằng Vercel platform.
data:image/s3,"s3://crabby-images/7bc36/7bc36bd9216c8df2bf231b791170f5e26cadd2a3" alt="Final result"
Cần chuẩn bị
- Cài đặt sẵn NodeJS (v12.0 trở lên), Yarn
- Setup trước một Github Repository cho project để push code deploy
- Hiểu cơ bản về loader, plugins của Webpack
Triển khai
yarn create next-app
data:image/s3,"s3://crabby-images/09f09/09f09fe1efac7d73555f9fb8a98dc406e318e3c1" alt="H1. Install next-js"
Ở đây mình tạm đặt tên project là shopping_matt (các bạn có thể đặt gì tuỳ ý nhé)
Sau khi đợi cài đặt xong sẽ thấy cấu trúc source như thế này:
data:image/s3,"s3://crabby-images/4f74f/4f74f54de94fa0be279f74337e6c483adc2830e3" alt="H2. Project structure"
Tiếp theo các bạn thử chạy lệnh sau để start xem hình hài em nó như nào nhé:
yarn start
Truy cập vào đường dẫn localhost:3000
, sẽ thấy được như sau:
data:image/s3,"s3://crabby-images/57f34/57f341dd6040b9affd97a372462909fec9155505" alt="H3. Install success"
1 Làm sao để setup SCSS module để vừa có thể code CSS hay SCSS đều được?
1- Cài package sass
npm:
npm i sass
2- Thử nghiệm chuyển css sang scss:
Duplicate file Home.module.css
và đổi tên thành Home.module.scss
Sau đó các bạn vào file path/to/pages/index.js
, sửa lại code import module như sau:
import styles from '../styles/sass/Home.module.scss'
data:image/s3,"s3://crabby-images/9137f/9137fadbed1b21882614856b322cb467a8ee1e1f" alt="H4. Import SCSS file"
⚠️ Lưu ý: quy tắc đặt tên cho file styling luôn luôn là:
[name].module.scss
Vì trong NextJS họ sử dụng CSS modules locally scope, lý do là để tránh tình trạng collisions dù cho có sử dụng trùng class name ở các file khác nhau
(các bạn có thể đọc thêm tại đây)
3- Test thử xem file scss mới có work chưa
Mở file Home.module.scss
, và chỉnh sửa lại code như sau:
1 2 3 4 |
.title a { color: #d700f3; // old: #0070f3 text-decoration: none; } |
Vậy là chúng ta đã done phần setup module SCSS phục vụ cho việc styling rồi.
2 Làm sao để tích hợp TailwindCSS vào NextJS?
1- Cài đặt package theo khuyến cáo của TailwindCSS (tuỳ theo version NextJS các bạn đang cài)
1 2 3 4 5 |
# If you're on Next.js v10 or newer npm install -D tailwindcss@latest postcss@latest autoprefixer@latest # If you're on Next.js v9 or older npm install -D tailwindcss@npm:@tailwindcss/postcss7-compat postcss@^7 autoprefixer@^9 |
2- Generate các file configure cần thiết:
npx tailwindcss init -p
Sau khi chạy thì các bạn sẽ thấy như sau:
data:image/s3,"s3://crabby-images/f088f/f088fd5ae04046c27c2f364bcc01e0e98ac8a793" alt="H6. CLI generate configure files"
data:image/s3,"s3://crabby-images/e4ccf/e4ccf266cb3ff5b09dbfc545f56d35dc1ea819bb" alt="H7. Successful generate"
3- Chỉnh sửa các file cấu hình tailwind.config.js
Sửa lại config trong option purge
, để khi deploy production, Tailwind sẽ tự clear những file không dùng tới trong stylings
1 |
purge: ['./pages/**/*.{js,ts,jsx,tsx}', './components/**/*.{js,ts,jsx,tsx}'], |
purge
option config
4- Import Tailwind vào project
Mở file path/to/styles/sass/global.scss
, và thêm vào các dòng sau:
1 2 3 4 |
/* ./styles/sass/global.scss */ @tailwind base; @tailwind components; @tailwind utilities; |
5- Kiểm tra thử xem liệu Tailwind đã được tích hợp thành công chưa
Cách 1: dùng Chrome devtool và thêm thủ công một utility-class vào như sau
data:image/s3,"s3://crabby-images/d539c/d539c81b552e44c0e02c496f9fbf7097fc8938f3" alt="H9. Chrome devtool test"
data:image/s3,"s3://crabby-images/7a261/7a261ea4a88654e2594f95a4bfb659e041bf4292" alt="H10. Chrome test successful"
Cách 2: sửa code demo trong file path/to/pages/index.js
, bằng cách add thêm một class bg-yellow-500
theo cú pháp sau
data:image/s3,"s3://crabby-images/7f798/7f79865e21334d119a0f693d9428bf44bd71eca2" alt="H11. Update code test"
Và chúng ta vẫn sẽ nhận được sự thay đổi giống như ở Hình H10 bên trên.
3 Deploy lên server Vercel như thế nào?
1- Truy cập vào link https://vercel.com/ để đăng nhập hoặc tạo tài khoản
Trong bài viết này thì mình đăng nhập bằng Github:
data:image/s3,"s3://crabby-images/957c6/957c6da4c29dc4a99e1b453dbaef96478ce25f0e" alt="H12. Github login"
2- Khởi tạo Project và liên kết với Github repo
data:image/s3,"s3://crabby-images/45911/45911c6d7d8ac73bdeeb9fda7c7c4aa06a9b48e7" alt="H13. Start creating project"
Tiếp theo thì các bạn cấp quyền cho Vercel liên kết với Repo đã tạo bên Github:
data:image/s3,"s3://crabby-images/9144a/9144a650a314550d924646557e5a02f9262d68ec" alt="H14. Link github repo and import"
3- Tiến hành cấu hình
Sau khi bấm Import thì các bạn sẽ đến bước cấu hình, điền thông tin cũng khá đơn giản:
data:image/s3,"s3://crabby-images/bc5e3/bc5e37f4c8610fc6844d894027f67ac034871f85" alt="H15. Fill-in configure info"
- 1,2: các bạn có thể bấm Skip nếu không có nhu cầu tạo Team (mình cũng vậy hehe)
- 3: đặt tên cho project của các bạn. Ở đây mình đặt là
shopping-matt-nextjs
.
Sau khi đặt tên xong, các bạn có thể để tuỳ chọn mặc định như bên dưới đây và bấm Deploy:
data:image/s3,"s3://crabby-images/16dae/16dae030eddf9ce9c9f1f91cc14c68190b61ba07" alt="H16. Ready for deploying"
data:image/s3,"s3://crabby-images/1ce4a/1ce4ad7ae633a008168cc47f5812af2b35606310" alt="H17. Start deploying"
data:image/s3,"s3://crabby-images/bd63b/bd63b94cd331b53d09d5f16f6495899559ae8c10" alt="H18. Deploying process"
data:image/s3,"s3://crabby-images/89db1/89db10afb773d5ff2f5d9f64c2ce91ca76a3289d" alt="H19. Deploy success!"
Đến đây thì gần như mọi thứ đã hoàn tất rồi.
data:image/s3,"s3://crabby-images/401dc/401dc7637e3dcbc569686e84083f039a20928268" alt="H20. Preview"
Click thử vào Go to Dashboard để xem bên trong có gì.
data:image/s3,"s3://crabby-images/d5758/d5758850531e92e790588f149079431d4bd7e932" alt="H21. Review"
Giờ thì bấm chọn Visit để cùng chiêm ngưỡng thành quả xem thế nào nhé!
data:image/s3,"s3://crabby-images/82962/82962a000cfaca5b1c08e92dd4065e8af81acf8c" alt="H22. Deployment log"
data:image/s3,"s3://crabby-images/1a09b/1a09b80908a974f3c925002dc5794a5a19214fa6" alt="H23. Production"
Vậy là chúng ta đã deploy thành công project demo NextJS lên production bằng nền tảng serverless Vercel rồi! Wohoo 🎉
Tổng kết
Sau bài viết này thì chúng ta đã hoàn thành các mục tiêu:
1- Cài đặt demo project dùng NextJS
2- Biết cách tích hợp SCSS/SASS module loader
3- Biết cách tích hợp TailwindCSS utility-first CSS framework
4- Deploy lên production bằng nền tảng Vercel serverless
Chúc các bạn demo thành công!
Tham khảo:
- TailwindCSS with Nextjs: https://tailwindcss.com/docs/guides/nextjs
- Introduction to Vercel: https://vercel.com/docs/introduction
- Adding Component-level CSS: https://nextjs.org/docs/basic-features/built-in-css-support#adding-component-level-css