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

Content Protection by DMCA.com

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.

Content Protection by DMCA.com