Django系列教程(4)——实例项目任务管理小应用

news/2025/3/14 8:51:48/

目录

第一步:创建tasks应用,加入INSTALLED_APPS

第二步:创建Task模型及其关联表单

第三步:编写路由URLConf及视图

第四步:编写模板

第五步:运行项目,查看效果

GitHub源码地址

小结


本例中我们只讲述核心逻辑,不浪费时间在前端样式上。文末有GitHub源码地址,里面同时包含了函数视图和基于类的视图, 具体演示效果如下所示:

第一步:创建tasks应用,加入INSTALLED_APPS

本例假设你已经有了一个mysite的Django项目。我们首先使用 python manage.py startapp tasks 创建一个名为”tasks”的app,并把它计入到settings.py的INSTALLED_APPS中去。

# mysite/settings.py
INSTALLED_APPS = ['django.contrib.admin','django.contrib.auth','django.contrib.contenttypes','django.contrib.sessions','django.contrib.messages','django.contrib.staticfiles','tasks',]

然后把app下的urls路径添加到项目文件夹的urls.py里去。

 from django.contrib import adminfrom django.urls import path, includeurlpatterns = [path('admin/', admin.site.urls),path('tasks/', include('tasks.urls'))]

第二步:创建Task模型及其关联表单

我们的Task模型非常简单,仅包含name和status两个字段。我们还使用ModelForm类创建了TaskForm,我们在创建任务或更新任务时需要用到这个表单。

# tasks/models.pyfrom django.db import modelsclass Status(models.TextChoices):UNSTARTED = 'u', "Not started yet"ONGOING = 'o', "Ongoing"FINISHED = 'f', "Finished"class Task(models.Model):name = models.CharField(verbose_name="Task name", max_length=65, unique=True)status = models.CharField(verbose_name="Task status", max_length=1, choices=Status.choices)def __str__(self):return self.name# tasks/forms.pyfrom .models import Taskfrom django import formsclass TaskForm(forms.ModelForm):class Meta:model = Taskfields = "__all__"

第三步:编写路由URLConf及视图

我们需要创建5个urls, 对应5个函数视图。这是因为对于Retrieve操作,我们需要编写两个函数视图,一个用户获取任务列表,一个用于获取任务详情。对于task_detailtask_updatetask_delete这个三个视图函数,我们还需要通过urls传递任务id或pk参数,否则它们不知道对哪个对象进行操作。

# tasks/urls.pyfrom django.urls import path, re_pathfrom . import views# namespaceapp_name = 'tasks'urlpatterns = [# Create a taskpath('create/', views.task_create, name='task_create'),# Retrieve task listpath('', views.task_list, name='task_list'),# Retrieve single task objectre_path(r'^(?P<pk>\d+)/$', views.task_detail, name='task_detail'),# Update a taskre_path(r'^(?P<pk>\d+)/update/$', views.task_update, name='task_update'),# Delete a taskre_path(r'^(?P<pk>\d+)/delete/$', views.task_delete, name='task_delete'),]

下面5个函数视图代码是本应用的核心代码,请仔细阅读并去尝试理解每一行代码。

# tasks/views.pyfrom django.shortcuts import render, redirect, get_object_or_404from django.urls import reversefrom .models import Taskfrom .forms import TaskForm# Create a taskdef task_create(request):# 如果用户通过POST提交,通过request.POST获取提交数据if request.method == "POST":# 将用户提交数据与TaskForm表单绑定form = TaskForm(request.POST)# 表单验证,如果表单有效,将数据存入数据库if form.is_valid():form.save()# 跳转到任务清单return redirect(reverse("tasks:task_list"))else:# 否则空表单form = TaskForm()return render(request, "tasks/task_form.html", { "form": form, })# Retrieve task listdef task_list(request):# 从数据库获取任务清单tasks = Task.objects.all()# 指定渲染模板并传递数据return render(request, "tasks/task_list.html", { "tasks": tasks,})# Retrieve a single taskdef task_detail(request, pk):# 从url里获取单个任务的pk值,然后查询数据库获得单个对象task = get_object_or_404(Task, pk=pk)return render(request, "tasks/task_detail.html", { "task": task, })# Update a single taskdef task_update(request, pk):# 从url里获取单个任务的pk值,然后查询数据库获得单个对象实例task_obj = get_object_or_404(Task, pk=pk)if request.method == 'POST':form = TaskForm(instance=task_obj, data=request.POST)if form.is_valid():form.save()return redirect(reverse("tasks:task_detail", args=[pk,]))else:form = TaskForm(instance=task_obj)return render(request, "tasks/task_form.html", { "form": form, "object": task_obj})# Delete a single taskdef task_delete(request, pk):# 从url里获取单个任务的pk值,然后查询数据库获得单个对象task_obj = get_object_or_404(Task, pk=pk)task_obj.delete() # 删除然后跳转return redirect(reverse("tasks:task_list"))

第四步:编写模板

虽然我们有5个urls,但我们只需要创建3个模板:task_list.htmltask_detail.html 和task_form.html。 最后一个模板由task_create 和task_update 视图函数共享。我们在模板中对实例对象进行判断,如果对象已存在则模板对于更新任务,否则是创建任务。task_delete视图不需要模板。

# tasks/templates/tasks/task_list.html<!DOCTYPE html><html lang="en"><head><meta charset="UTF-8"><title>Task List</title></head><body><h3>Task List</h3>{% for task in tasks %}<p>{{ forloop.counter }}. {{ task.name }} - {{ task.get_status_display }}(<a href="{% url 'tasks:task_update' task.id %}">Update</a> |<a href="{% url 'tasks:task_delete' task.id %}">Delete</a>)</p>{% endfor %}<p> <a href="{% url 'tasks:task_create' %}"> + Add A New Task</a></p></body></html># tasks/templates/tasks/task_detail.html<!DOCTYPE html><html lang="en"><head><meta charset="UTF-8"><title>Task Detail</title></head><body><p> Task Name: {{ task.name }} | <a href="{% url 'tasks:task_update' task.id %}">Update</a> |<a href="{% url 'tasks:task_delete' task.id %}">Delete</a></p><p> Task Status: {{ task.get_status_display }} </p><p> <a href="{% url 'tasks:task_list' %}">View All Tasks</a> |<a href="{% url 'tasks:task_create'%}">New Task</a></p></body></html># tasks/templates/tasks/task_form.html<!DOCTYPE html><html lang="en"><head><meta charset="UTF-8"><title>{% if object %}Edit Task {% else %} Create New Task {% endif %}</title></head><body><h3>{% if object %}Edit Task {% else %} Create New Task {% endif %}</h3><form action="" method="post" enctype="multipart/form-data">{% csrf_token %}{{ form.as_p }}<p><input type="submit" class="btn btn-success" value="Submit"></p></form></body></html> 

第五步:运行项目,查看效果

运行如下命令,访问http://127.0.0.1:8000/tasks/就应该看到文初效果了。

 python manage.py makemigrationspython manage.py migratepython manage.py runserver

GitHub源码地址

本项目源码地址,里面同时包含了函数视图和基于类的视图。

小结

本例中我们使用了函数视图(functional-based views, FBV)编写了一个任务管理的CRUD小应用,后面我们将使用基于类的视图(class-based views, CBV)重写本例演示代码。

接下来几章我们将详细介绍模型、视图、URL的配置以及模板的基础知识,欢迎关注。


http://www.ppmy.cn/news/1578668.html

相关文章

2.装饰器模式

概述 装饰器模式&#xff1a;在原有结构&#xff0c;动态地为对象添加职责&#xff0c;它是一种灵活的扩展功能方式。 业务场景&#xff1a;创建订单 假设你正在开发一个电商系统&#xff0c;用户在创建订单时可以选择不同的服务&#xff08;如折扣、配送、礼品包装等&#…

Docker基础之运行原理

docker run的一个执行流程 Docker是一个Client-Server 的结构的系统&#xff0c;Docker的守护进程在主机上&#xff0c;通过Socker从客户端来访问 DockerServer接收到Docker-Client的指令&#xff0c;就会执行这个命令 Docker为什么比Linux快&#xff1f; 1.Docker有着比虚拟机…

LeetCode 2269.找到一个数字的 K 美丽值:字符串数字转换(模拟)

【LetMeFly】2269.找到一个数字的 K 美丽值&#xff1a;字符串数字转换(模拟) 力扣题目链接&#xff1a;https://leetcode.cn/problems/find-the-k-beauty-of-a-number/ 一个整数 num 的 k 美丽值定义为 num 中符合以下条件的 子字符串 数目&#xff1a; 子字符串长度为 k 。…

有哪些好用的AI视频加工创作网站

以下是当前较为流行且功能强大的AI视频创作与加工平台&#xff0c;涵盖视频生成、编辑、特效及自动化处理等功能&#xff0c;适合不同需求的用户&#xff1a; 一、AI视频生成工具 1. Synthesia - 特点&#xff1a;AI虚拟人像生成&#xff0c;支持100语言配音&#xff0c;无…

node.js内置模块之---crypto 模块

crypto 模块的作用 在 Node.js 中&#xff0c;crypto 模块提供了多种加密功能&#xff0c;包括哈希、对称加密、非对称加密和数字签名等。通过 crypto 模块&#xff0c;可以进行各种加密和解密操作&#xff0c;保护敏感数据的安全性。 crypto 模块 1. 哈希算法&#xff08;H…

c#面试题整理7

1.UDP和TCP的区别 UDP是只要能连上终端就发送&#xff0c;至于终端是否收到&#xff0c;不管。 TCP则是会存在交换&#xff0c;即发送失败或成功&#xff0c;是可知的。 2.进程和线程的区别 双击一个程序的exe文件&#xff0c;程序执行了&#xff0c;这就是一个进程。 这个…

SQLiteStudio:一款免费开源跨平台的SQLite管理工具

目录 1.简介 2.下载与安装 3.实现分析 4.总结 1.简介 SQLiteStudio 是一款专门用于管理 SQLite 数据库的图形化工具&#xff0c;由波兰开发者开发并维护。由于 SQLite 以其轻量级、零配置、嵌入式等特性被广泛应用于各种小型项目、移动应用和桌面应用中&#xff0c;而 SQLi…

linux 软件安装(上)

一、基础环境准备 1.1、安装VM 1.2、在VM上导入linux iso镜像&#xff0c;装好linux系统 华为centos镜像下载地址 https://mirrors.huaweicloud.com/centos/ https://mirrors.huaweicloud.com/centos/7.9.2009/isos/x86_64/ 网易centos镜像下载地址 htt…