Lập trình tốc độ: Xây Dựng Ứng Dụng Đầu Tiên Với Wasp

Nội dung

Trong bài viết này, chúng ta sẽ cùng nhau xây dựng ứng dụng web đầu tiên với Wasp. Bài viết sẽ hướng dẫn bạn từ bước khởi tạo dự án mới, cấu trúc thư mục và file, tạo các trang cơ bản, kết nối cơ sở dữ liệu đến việc chạy và kiểm tra ứng dụng.

Khởi Tạo Dự Án Mới Với Wasp

Cài Đặt Wasp

Trước khi bắt đầu, hãy đảm bảo rằng bạn đã cài đặt công cụ dòng lệnh của Wasp. Nếu chưa, bạn có thể cài đặt nó thông qua npm:

npm install -g @wasp/cli

Khởi Tạo Dự Án

Sau khi đã cài đặt Wasp CLI, bạn có thể tạo dự án mới bằng lệnh sau:

wasp new my-first-wasp-app
cd my-first-wasp-app

Lệnh này sẽ tạo ra một thư mục dự án mới với tên my-first-wasp-app và chuyển bạn vào thư mục đó.

Cấu Trúc Thư Mục Và File Trong Dự Án Wasp

Khi bạn khởi tạo dự án Wasp, bạn sẽ thấy một số thư mục và file quan trọng sau:

  • main.wasp: Đây là file chính nơi bạn định nghĩa cấu trúc và logic của ứng dụng.
  • src/: Thư mục chứa mã nguồn React và server.
  • ext/: Thư mục chứa các file mở rộng và cấu hình tùy chỉnh.

Dưới đây là cấu trúc cơ bản của dự án:

my-first-wasp-app/
├── ext/
├── src/
│ ├── client/
│ │ ├── MainPage.js
│ │ └── ...
│ ├── server/
│ │ └── ...
├── main.wasp
└── package.json

Tạo Các Trang (Pages) Cơ Bản

Định Nghĩa Trang Chính

Trong Wasp, các trang được định nghĩa trong file main.wasp. Để tạo trang chính (MainPage), bạn cần thêm đoạn mã sau vào main.wasp:

page Main {
  route: "/"
  component: MainPage
}

Tạo Thành Phần React Cho Trang Chính

Tiếp theo, bạn cần tạo thành phần React tương ứng trong thư mục src/client/. Tạo file MainPage.js với nội dung sau:

import React from 'react';

const MainPage = () => {
  return (
    <div>
      <h1>Welcome to My First Wasp App!</h1>
      <p>This is the main page of your application.</p>
    </div>
  );
};

export default MainPage;

Cập Nhật Định Nghĩa Trang Chính

Đảm bảo rằng main.wasp đã được cập nhật đầy đủ:

page Main {
  route: "/"
  component: MainPage
}

Kết Nối Cơ Sở Dữ Liệu

Wasp hỗ trợ kết nối cơ sở dữ liệu một cách dễ dàng. Trong ví dụ này, chúng ta sẽ tạo một thực thể (entity) Task để quản lý các công việc.

Định Nghĩa Thực Thể

Thêm đoạn mã sau vào main.wasp để định nghĩa thực thể Task:

entity Task {
  description: string
  isDone: boolean
}

Tạo API Để Quản Lý Thực Thể

Tiếp theo, bạn cần tạo các API để quản lý thực thể Task. Thêm đoạn mã sau vào main.wasp:

route Tasks {
  method: GET
  handler: tasksHandler
}

route CreateTask {
  method: POST
  handler: createTaskHandler
}

Tạo Thành Phần React Để Hiển Thị Và Thêm Task

Cập nhật MainPage.js để hiển thị danh sách Task và thêm Task mới:

import React, { useState, useEffect } from 'react';

const MainPage = () => {
  const [tasks, setTasks] = useState([]);
  const [newTaskDescription, setNewTaskDescription] = useState('');

  useEffect(() => {
    fetch('/tasks')
      .then(response => response.json())
      .then(data => setTasks(data));
  }, []);

  const handleAddTask = () => {
    fetch('/createTask', {
      method: 'POST',
      headers: {
        'Content-Type': 'application/json',
      },
      body: JSON.stringify({ description: newTaskDescription, isDone: false }),
    })
      .then(response => response.json())
      .then(task => setTasks([...tasks, task]));
  };

  return (
    <div>
      <h1>Welcome to My First Wasp App!</h1>
      <p>This is the main page of your application.</p>
      <input
        type="text"
        value={newTaskDescription}
        onChange={(e) => setNewTaskDescription(e.target.value)}
      />
      <button onClick={handleAddTask}>Add Task</button>
      <ul>
        {tasks.map(task => (
          <li key={task.id}>
            {task.description} - {task.isDone ? 'Done' : 'Not Done'}
          </li>
        ))}
      </ul>
    </div>
  );
};

export default MainPage;

Chạy Và Kiểm Tra Ứng Dụng

Sau khi đã hoàn tất các bước trên, bạn có thể chạy ứng dụng bằng lệnh:

wasp start

Ứng dụng sẽ được khởi động và bạn có thể truy cập nó thông qua trình duyệt web tại địa chỉ http://localhost:3000.

Kiểm Tra Ứng Dụng

Mở trình duyệt và truy cập http://localhost:3000. Bạn sẽ thấy trang chính của ứng dụng với khả năng hiển thị danh sách Task và thêm Task mới. Hãy thử thêm một vài Task để kiểm tra chức năng của ứng dụng.

Kết Luận

Qua bài viết này, bạn đã học cách xây dựng ứng dụng web đầu tiên với Wasp từ việc khởi tạo dự án, cấu trúc thư mục và file, tạo các trang cơ bản, kết nối cơ sở dữ liệu đến việc chạy và kiểm tra ứng dụng. Wasp thực sự là một công cụ mạnh mẽ và hữu ích giúp đơn giản hóa quy trình phát triển ứng dụng web, tiết kiệm thời gian và giảm thiểu lỗi. Hy vọng rằng qua bài viết này, bạn sẽ cảm thấy tự tin hơn khi sử dụng Wasp trong các dự án của mình.

Anthony Nguyễn

Cây bút chính tại VietnamTutor

Bài viết cùng chuyên mục

Git reset revert restore: chọn lệnh đúng

Bài viết so sánh git reset, git revert và git restore theo mục đích sử dụng: sửa staging area, khôi phục file, undo commit chưa push

Git commit vào nhánh sai: cách chuyển an toàn

Bài viết hướng dẫn xử lý git commit vào nhánh sai theo từng tình huống: commit chưa push, đã push, nhiều commit liên tiếp hoặc branch

TypeScript cho website doanh nghiệp: API, form và lỗi

TypeScript cho website doanh nghiệp đáng dùng khi bạn cần kiểm soát API contract, form schema, CMS payload và cấu hình môi trường. Bài này giúp

React Server Components performance: khi nào nên dùng?

React Server Components performance không phải phép màu. Bài này giúp bạn biết khi nào RSC giảm JavaScript thật, khi nào làm kiến trúc phức tạp

Git commit nhầm file: bỏ file khỏi commit an toàn

Bài viết hướng dẫn xử lý git commit nhầm file theo từng tình huống: chưa commit, đã commit chưa push, đã push lên remote, hoặc lỡ

Git reflog: khôi phục commit đã mất an toàn

Bài viết hướng dẫn dùng git reflog để khôi phục commit đã mất sau reset, rebase, amend hoặc xóa nhánh. Bạn sẽ biết cách đọc reflog,

Git pull bị conflict: cách sửa không mất code

Bài viết hướng dẫn cách xử lý git pull bị conflict theo từng bước: kiểm tra trạng thái, sửa file xung đột, test lại và hoàn

Next.js production performance: chọn SSR, SSG, ISR hay Edge

Bài viết giúp developer và tech lead chọn cách render phù hợp để tối ưu Next.js production performance mà không làm kiến trúc phức tạp quá

Nâng cấp Laravel 13: Checklist 10 bước cần kiểm tra

Hướng dẫn nâng cấp Laravel 13 chi tiết với checklist 10 bước. Từ kiểm tra PHP 8.3, cập nhật dependencies, đến xử lý lỗi thường gặp

Hardening Laravel production: Checklist bảo mật cần làm

Checklist hardening Laravel production toàn diện. Từ cấu hình server, database, SSL đến security headers, rate limiting và monitoring.

Authentication và authorization trong Laravel: Cách phân biệt

Hướng dẫn chi tiết cách xây dựng hệ thống Authentication (xác thực) và Authorization (phân quyền) trong Laravel với Breeze, Fortify, Sanctum, Policies và Gates.

Bảo mật Laravel: 10 lỗi phổ biến và cách phòng tránh

Hướng dẫn 10 lỗi bảo mật phổ biến nhất trong Laravel và cách phòng tránh hiệu quả. Từ XSS, SQL injection đến authentication vulnerabilities.