Huu Nghia Nguyen

Setup React Typescript với Vite, ESLint & Tailwindcss

Vite dạo gần đây đang là xu hướng, vì cách setup đơn giản và tốc độ thực thi nhanh hơn nhiều so với Webpack.

0
10
Setup React Typescript với Vite, ESLint & Tailwindcss

Sau đây là một số ưu điểm của vite:

  1. Tốc độ build nhanh: Vite thiết kế để có hiệu suất build và tải lại nhanh hơn, đặc biệt trong quá trình phát triển.
  2. Live-reloading tốt: Hỗ trợ Hot Module Replacement, giúp cập nhật ngay lập tức các thay đổi mà không tải lại toàn bộ trang.
  3. Tích hợp mượt mà với Vue: Đặc biệt tối ưu cho phát triển ứng dụng Vue.js.
  4. Tree-shaking tốt: Loại bỏ mã không sử dụng, giúp giảm dung lượng bundle.
  5. Không cần cấu hình nhiều: Sử dụng được ngay mà không cần nhiều cấu hình, đặc biệt là cho dự án nhỏ và trung bình.

Lưu ý: Vite thường được ưa chuộng trong các dự án nhỏ đến trung bình và có yêu cầu về tốc độ phát triển nhanh. Webpack vẫn là lựa chọn mạnh mẽ và linh hoạt cho các dự án lớnđa dạng.

Cấu trúc thư mục ReactJs Vite

Dưới đây là cấu trúc thư mục hoàn chỉnh của dự án ReactJs Typescript Vite ESLint Tailwindcss Prettier

📦react-app
 ┣ 📂dist
 ┣ 📂public
 ┃ ┗ 📜vite.svg
 ┣ 📂src
 ┃ ┣ 📂assets
 ┃ ┃ ┗ 📜react.svg
 ┃ ┣ 📜App.css
 ┃ ┣ 📜App.tsx
 ┃ ┣ 📜index.css
 ┃ ┣ 📜main.tsx
 ┃ ┗ 📜vite-env.d.ts
 ┣ 📜.editorconfig
 ┣ 📜.eslintignore
 ┣ 📜.eslintrc.cjs
 ┣ 📜.gitignore
 ┣ 📜.prettierignore
 ┣ 📜.prettierrc
 ┣ 📜index.html
 ┣ 📜package-lock.json
 ┣ 📜package.json
 ┣ 📜postcss.config.js
 ┣ 📜tailwind.config.js
 ┣ 📜tsconfig.json
 ┣ 📜tsconfig.node.json
 ┗ 📜vite.config.ts
  • Thư mục dist: Thư mục chứa các file build
  • Thư mục public: Chứa file index.html và các file liên quan như favicon.icorobots.txt,…
  • Thư mục src: Chứa mã nguồn chính của chúng ta
  • Thư mục src/assets: Chứa media, css (file App.css và index.css ở trên mình để nguyên xi khi mới tạo
  • Còn lại những file config sẽ được mình giới thiệu ở những phần dưới

Bước 1 – Khởi tạo dự án Vite

Vite yêu cầu Node version 14.18+, 16+ để có thể hoạt động ổn định. Tuy nhiên một số template yêu cầu version cao hơn, vậy nên nếu nó warning thì mọi người update nodejs lên version cao hơn nhé.

Các bạn có thể dùng npm hoặc yarn hoặc pnpm đều được, ở đây mình dùng npm cho đơn giản.

Với npm

npm create vite@latest

Với Yarn

yarn create vite

Với PNPM

pnpm create vite

Sau khi chạy thì nó sẽ yêu cầu nhập tên dự án

Need to install the following packages:

create-vite@4.1.0

Ok to proceed? (y) y

✔ Project name: … react-app

Tiếp theo là chọn Framework

✔ Select a framework: › React

Chọn template, ở đây mình chọn TypeScript + SWCSWC sẽ thay thế Babel cho việc biên dịch code Typescript/Javascript. SWC có tốc độ nhanh hơn 20 lần khi so với Babel

✔ Select a variant: › TypeScript + SWC

Tiếp theo là thư mục vừa được Vite tạo

cd react-app

Cài đặt các package

npm install

Bước 2 – Cài các package liên quan ESLint và Prettier

Sau khi xong bước 1 rồi thì mặc định Vite đã giúp chúng ta cấu hình cơ bản cho ESLint và TypeScript rồi, nhưng để tiện hơn cho việc code thì chúng ta sẽ cài thêm 1 số package nữa.

Chạy câu lệnh sau

npm i prettier eslint-config-prettier eslint-plugin-prettier -D

Đây là những thứ chúng ta cài

  • prettier: code formatter chính
  • eslint-config-prettier: Bộ config ESLint để vô hiệu hóa các rule của ESLint mà xung đột với Prettier.
  • eslint-plugin-prettier: Dùng thêm 1 số rule Prettier cho ESLint

Bước 3 – Config ESlint để chuẩn hóa code

Mở file .eslintrc.cjs lên

Thêm đoạn giá trị này vào mảng ignorePatterns, mục đích là mình không muốn ESLint check file vite.config.ts

'vite.config.ts'

Thêm đoạn code sau vào mảng extends

'eslint-config-prettier', 'prettier'

Thêm đoạn code sau vào mảng plugins

'prettier'

Thêm đoạn code sau vào object rules để thêm các rule của Prettier

'prettier/prettier': [
      'warn',
      {
        arrowParens: 'always',
        semi: false,
        trailingComma: 'none',
        tabWidth: 2,
        endOfLine: 'auto',
        useTabs: false,
        singleQuote: true,
        printWidth: 120,
        jsxSingleQuote: true
      }
    ]


Bước 4 – Config Prettier để format code

Tạo file .prettierrc trong thư trong thư mục root với nội dung dưới đây

{
  "arrowParens": "always",
  "semi": false,
  "trailingComma": "none",
  "tabWidth": 2,
  "endOfLine": "auto",
  "useTabs": false,
  "singleQuote": true,
  "printWidth": 120,
  "jsxSingleQuote": true
}

Mục đích là cấu hình prettier. Anh em nên cài Extension Prettier - Code formatter cho VS Code để nó hiểu nhé.

Tiếp theo Tạo file .prettierignore ở thư mục root

Mục đích là Prettier bỏ qua các file không cần thiết

node_modules/
dist/

Bước 5 – Config editor để chuẩn hóa cấu hình editor

Tạo file .editorconfig ở thư mục root

Mục đích là cấu hình các config đồng bộ các editor với nhau nếu dự án có nhiều người tham gia.

Để VS Code hiểu được file này thì anh em cài Extension là EditorConfig for VS Code nhé

[*]
indent_size = 2
indent_style = space

Bước 6 – Cấu hính alias cho tsconfig.json

Việc thêm alias vào file tsconfig.json sẽ giúp VS Code hiểu mà tự động import giúp chúng ta. Lưu ý cái này chỉ giúp

Thêm đoạn này vào compilerOptions trong file tsconfig.json

"baseUrl": ".",
"paths": {
  "src/*": ["src/*"]
}

Ý nghĩa của đoạn này là ta có thể import Login from 'src/pages/Login' thay vì import Login from '../../pages/Login'. Ngắn gọn và dễ nhìn hơn nhiều!


Bước 7 – Cấu hình alias cho vite vite.config.ts

Cài package @types/node để sử dụng node js trong file ts không bị lỗi

npm i @types/node -D

Cấu hình alias và enable source map ở file vite.config.ts

import { defineConfig } from 'vite'
import react from '@vitejs/plugin-react-swc'
import path from 'path'

// https://vitejs.dev/config/
export default defineConfig({
  plugins: [react()],
  server: {
    port: 3000
  },
  css: {
    devSourcemap: true
  },
  resolve: {
    alias: {
      'src': path.resolve(__dirname, './src')
    }
  }
})

Bước 8 – Cập nhật script cho package.json

Mở file package.json lên, thêm đoạn script dưới vào

"scripts": {
    //...
    "lint:fix": "eslint --fix src --ext ts,tsx",
    "prettier": "prettier --check \"src/**/(*.tsx|*.ts|*.css|*.scss)\"",
    "prettier:fix": "prettier --write \"src/**/(*.tsx|*.ts|*.css|*.scss)\""
}

Bước 9 – Cài đặt Tailwindcss

Cài đặt tailwindcss, chạy câu lệnh sau

npm install -D tailwindcss postcss autoprefixer
npx tailwindcss init -p

Cấu hình content ở file tailwind.config.js

/** @type {import('tailwindcss').Config} */
export default {
  content: [
    "./index.html",
    "./src/**/*.{js,ts,jsx,tsx}",
  ],
  theme: {
    extend: {},
  },
  plugins: [],
}

Thêm @tailwind chỉ thị cho từng lớp của Tailwind vào tệp ./src/index.css

@tailwind base;
@tailwind components;
@tailwind utilities;

Câu lệnh để chạy dự án

Đến đây là xong rồi đó, để chạy trong môi trường dev thì chúng ta sẽ chạy bằng câu lệnh npm run dev.

Nếu muốn build thì npm run build

Ngoài ra còn có một số câu lệnh như

  • Preview kết quả build bằng câu lệnh npm run preview
  • Kiểm tra dự án có bị lỗi gì liên quan ESLint không: npm run lint
  • Tự động fix các lỗi liên quan ESLint (không phải cái gì cũng fix được, nhưng fix cũng nhiều): npm run lint:fix
  • Kiểm tra dự án có bị lỗi gì liên quan Prettier không: npm run prettier
  • Tự động fix các lỗi liên quan Prettier: npm run prettier:fix

Sourcecode boilerplate

Link here: https://github.com/huunghianguyenish/react-vite-boilerplate

Responses (0 )