DJANGO
CÁC CHỦ ĐỀ
BÀI MỚI NHẤT
MỚI CẬP NHẬT

Thông báo: Download 4 khóa học Python từ cơ bản đến nâng cao tại đây.

Django DetailView trong Python

Trong bài viết này, bạn sẽ học cách sử dụng lớp Django DetailView để hiển thị chi tiết của một đối tượng. Django DetailView là một trong những class-based views mạnh mẽ và tiện lợi nhất của Django, giúp bạn dễ dàng xây dựng các trang web hiển thị thông tin chi tiết của các đối tượng trong cơ sở dữ liệu của bạn. Hướng dẫn này tiếp nối từ phần cuối của hướng dẫn Django ListView, giúp bạn hiểu rõ hơn cách sử dụng và triển khai DetailView trong dự án Django của mình. Bạn sẽ học cách định nghĩa DetailView, tạo template chi tiết, và thiết lập các route cần thiết để hoàn thiện web của bạn.

test php

banquyen png
Bài viết này được đăng tại freetuts.net, không được copy dưới mọi hình thức.

Django DetailView trong Python là gì?

Django DetailView cho phép bạn định nghĩa một class-based view để hiển thị chi tiết của một đối tượng. Để sử dụng lớp DetailView, bạn định nghĩa một class kế thừa từ lớp DetailView.

Ví dụ, đoạn mã sau định nghĩa một class-based view tên là TaskDetail để hiển thị chi tiết của một nhiệm vụ trong ứng dụng Todo:

from django.shortcuts import render
from django.views.generic.list import ListView
from django.views.generic.detail import DetailView
from .models import Task

class TaskDetail(DetailView):
    model = Task
    context_object_name = 'task'

Cách hoạt động

Đầu tiên, import DetailView từ django.views.generic.detail:

Bài viết này được đăng tại [free tuts .net]

from django.views.generic.detail import DetailView

Thứ hai, định nghĩa một class tên là TaskDetail kế thừa từ DetailView. Trong class TaskDetail, chúng ta định nghĩa các thuộc tính sau:

  • model chỉ định lớp của đối tượng sẽ được hiển thị.
  • context_object_name chỉ định tên của đối tượng trong template. Mặc định, Django sử dụng object làm tên đối tượng trong template. Để rõ ràng hơn, chúng ta sử dụng task làm tên đối tượng.

Mặc định, class TaskDetail sẽ tải template có tên là task_detail.html từ thư mục templates/todo. Nếu bạn muốn sử dụng một tên template khác, bạn có thể sử dụng thuộc tính template_name trong class TaskDetail.

Tạo template task_detail.html Django trong Python

Tạo file template task_detail.html trong thư mục templates/todo với nội dung sau:

{%extends 'base.html'%}

{%block content%}
<article class="task">
    <header>
        <h2>{{ task.title }}</h2>
        <span class="badge {% if task.completed %}badge-completed{% else %}badge-pending{%endif%}">
            {% if task.completed %} Completed {%else%} Pending {%endif%}
        </span>
    </header>
    <p>{{task.description}}</p>
</article>
{%endblock content%}

Template task_detail.html mở rộng từ template base.html. Template này sử dụng đối tượng task và hiển thị các thuộc tính của nhiệm vụ bao gồm tiêu đề, trạng thái (hoàn thành hay chưa) và mô tả.

Khởi tạo route

Khởi tạo một route để ánh xạ URL hiển thị chi tiết một nhiệm vụ với kết quả của phương thức as_view() của class TaskDetail:

from django.urls import path
from .views import home, TaskList, TaskDetail

urlpatterns = [
    path('', home, name='home'),
    path('tasks/', TaskList.as_view(), name='tasks'),
    path('task/<int:pk>/', TaskDetail.as_view(), name='task'),
]

URL chấp nhận một số nguyên là id (hoặc khóa chính, pk) của nhiệm vụ. TaskDetail sẽ lấy tham số pk này, chọn nhiệm vụ từ cơ sở dữ liệu theo id, tạo một đối tượng Task và truyền nó vào template.

Sửa đổi template task_list.html

Sửa đổi template task_list.html để bao gồm liên kết tới từng nhiệm vụ trong danh sách sử dụng thẻ url:

{%extends 'base.html'%}

{%block content%}
<div class="center">
    <h2>My Todo List</h2>
    {% if tasks %}
    <ul class="tasks">
        {% for task in tasks %}
            <li>
                <a href="{% url 'task' task.id %}" class="{% if task.completed %}completed{%endif%}">{{ task.title }}</a>
                <div class="task-controls">
                    <a href="#"><i class="bi bi-trash"></i> </a>
                    <a href="#"><i class="bi bi-pencil-square"></i></a>
                </div>
            </li>
        {% endfor %}
    {% else %}
        <p>???? Yay, bạn không có nhiệm vụ nào đang chờ!</p>
    {% endif %}
    </ul>
</div>
{%endblock content%}

Khi bạn nhấp vào liên kết của từng nhiệm vụ, bạn sẽ được chuyển hướng đến trang chi tiết của nhiệm vụ đó.

Chạy server phát triển Django:

python manage.py runserver

Mở danh sách nhiệm vụ:

http://127.0.0.1:8000/tasks/

Bạn sẽ thấy danh sách các nhiệm vụ. Khi nhấp vào một nhiệm vụ, ví dụ: "Learn Python", bạn sẽ được chuyển hướng đến trang chi tiết của nhiệm vụ đó.

Kết bài

Việc sử dụng Django DetailView là một cách hiệu quả để hiển thị chi tiết của các đối tượng trong ứng dụng Django của bạn. Với những kiến thức bạn đã học được từ hướng dẫn này, bạn có thể dễ dàng triển khai các trang web hiển thị thông tin chi tiết của đối tượng một cách linh hoạt và tiện lợi. Hãy thử áp dụng các khái niệm và kỹ thuật đã học vào dự án của bạn và tận dụng Django để xây dựng các ứng dụng web và linh hoạt.

Cùng chuyên mục:

Cách dùng lớp PyQt QInputDialog để tạo một hộp thoại nhập liệu

Cách dùng lớp PyQt QInputDialog để tạo một hộp thoại nhập liệu

Cách sử dụng lớp PyQt QMessageBox để tạo một hộp thoại

Cách sử dụng lớp PyQt QMessageBox để tạo một hộp thoại

Cách sử dụng lớp PyQt QProgressBar để tạo một widget progress bar

Cách sử dụng lớp PyQt QProgressBar để tạo một widget progress bar

Cách dùng lớp PyQt QTextEdit để tạo một widget cho phép chỉnh sửa

Cách dùng lớp PyQt QTextEdit để tạo một widget cho phép chỉnh sửa

Cách dùng lớp PyQt QGroupBox để tạo một khung nhóm với tiêu đề

Cách dùng lớp PyQt QGroupBox để tạo một khung nhóm với tiêu đề

Cách dùng lớp PyQt QTabWidget để tạo một widget dạng tab

Cách dùng lớp PyQt QTabWidget để tạo một widget dạng tab

Cách dùng PyQt QWidget để làm container chứa các widget khác.

Cách dùng PyQt QWidget để làm container chứa các widget khác.

Cách sử dụng lớp PyQt QSlider để tạo một widget thanh trượt (slider).

Cách sử dụng lớp PyQt QSlider để tạo một widget thanh trượt (slider).

Cách tạo một widget nhập ngày và giờ sử dụng PyQt QDateTimeEdit

Cách tạo một widget nhập ngày và giờ sử dụng PyQt QDateTimeEdit

Cách tạo một widget nhập giờ sử dụng lớp PyQt QTimeEdit

Cách tạo một widget nhập giờ sử dụng lớp PyQt QTimeEdit

Cách tạo một widget nhập ngày sử dụng lớp PyQt QDateEdit

Cách tạo một widget nhập ngày sử dụng lớp PyQt QDateEdit

Cách sử dụng widget PyQt QSpinBox để tạo một spin box

Cách sử dụng widget PyQt QSpinBox để tạo một spin box

Sử dụng PyQt QComboBox để tạo Widget Combobox

Sử dụng PyQt QComboBox để tạo Widget Combobox

Cách sử dụng lớp PyQt QRadioButton

Cách sử dụng lớp PyQt QRadioButton

Cách sử dụng lớp QCheckBox trong PyQt

Cách sử dụng lớp QCheckBox trong PyQt

Cách sử dụng QFormLayout trong PyQt

Cách sử dụng QFormLayout trong PyQt

Cách sử dụng QGridLayout trong PyQt

Cách sử dụng QGridLayout trong PyQt

Cách sử dụng QVBoxLayout trong PyQt

Cách sử dụng QVBoxLayout trong PyQt

Cách sử dụng widget QLineEdit trong PyQt

Cách sử dụng widget QLineEdit trong PyQt

Cách sử dụng widget QPushButton của PyQt

Cách sử dụng widget QPushButton của PyQt

Top