【Javaer学习Python】2、Django的MVT设计模式,完成CRUD小应用

系列文章:学习Python

Django的MVT设计模式由Model(模型), View(视图) 和Template(模板)三部分组成,分别对应单个app目录下的models.py, views.py和templates文件夹。它们看似与MVC设计模式不太一致,其实本质是相同的;
实践是检验学习成果的最好方法,完成初级开发人员最熟悉的 CRUD 来练手,实现创建(Create)一个任务,查看(Retrieve)任务清单和单个任务详情,更新(Update)一个任务和删除(Delete)一个任务;

MVC 模型

MVC 模式(Model–view–controller)是软件工程中的一种软件架构模式,把软件系统分为三个基本部分:模型(Model)、视图(View)和控制器(Controller)。
MVC 以一种插件式的、松耦合的方式连接在一起。

  • 模型(M)- 编写程序应有的功能,负责业务对象与数据库的映射(ORM)。
  • 视图(V)- 图形界面,负责与用户的交互(页面)。
  • 控制器(C)- 负责转发请求,对请求进行处理。

简易图:
ModelViewControllerDiagramZh.png
用户操作流程图:
1589776521-2356-JxrlTyMyPgYnQpOV.png
熟悉的 Java MVC 的味道,异曲同工:在MVC框架中创建一个接收所有请求的Servlet,通常我们把它命名为DispatcherServlet,它总是映射到/,然后,根据不同的Controller的方法定义的@Get或@Post的Path决定调用哪个方法,最后,获得方法返回的ModelAndView后,渲染模板,写入HttpServletResponse,即完成了整个MVC的处理。

HTTP Request    	 ┌─────────────────┐
──────────────────>│DispatcherServlet│└─────────────────┘│┌────────────┼────────────┐▼            ▼            ▼┌───────────┐┌───────────┐┌───────────┐│Controller1││Controller2││Controller3│└───────────┘└───────────┘└───────────┘│            │            │└────────────┼────────────┘▼HTTP Response ┌────────────────────┐
<────────────────│render(ModelAndView)│└────────────────────┘

MTV 模型

Django 的 MTV 模式本质上和 MVC 是一样的,也是为了各组件间保持松耦合关系,只是定义上有些许不同,Django 的 MTV 分别是指:

  • M 表示模型(Model):编写程序应有的功能,负责业务对象与数据库的映射(ORM)。
  • T 表示模板 (Template):负责如何把页面(html)展示给用户。
  • V 表示视图(View):负责业务逻辑,并在适当时候调用 Model和 Template。

除了以上三层之外,还需要一个 URL 分发器,它的作用是将一个个 URL 的页面请求分发给不同的 View 处理,View 再调用相应的 Model 和 Template,MTV 的响应模式如下所示:
简易图:
MTV-Diagram.png
用户操作流程图:
1589777036-2760-fs1oSv4dOWAwC5yW.png
解析:
用户通过浏览器向我们的服务器发起一个请求(request),这个请求会去访问视图函数:

  • a.如果不涉及到数据调用,那么这个时候视图函数直接返回一个模板也就是一个网页给用户。
  • b.如果涉及到数据调用,那么视图函数调用模型,模型去数据库查找数据,然后逐级返回。

视图函数把返回的数据填充到模板中空格,最后返回网页给用户。

完成CRUD 小应用

crud.gif

1、创建Django项目,tasks应用

在 PyCharm 中 new Project,并创建应用:python manage.py startapp tasks并把它加入 settings.pyINSTALLED_APPS 中;
然后把app下的urls路径添加到项目文件夹的urls.py里去:

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

2、创建Task模型及其关联表单

# tasks/models.pyfrom django.db import modelsclass Status(models.TextChoices):UNSTARTED = 'u', "未开始"ONGOING = 'o', "进行中"FINISHED = 'f', "已结束"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__"

3、编写路由URLConf及视图

我们需要创建5个urls, 对应5个函数视图。

 from 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个函数视图代码是本应用的核心代码:

 from 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"))

4、编写模板

# 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://localhost/tasks/就应该看到文初效果了。
image.png

参考文档

Django 简介 | 菜鸟教程
Django CRUD小应用
MVC高级开发

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/706902.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux进程概念总结

这里总结下Linux进程概念总结❗ 冯诺依曼&#xff1a; CPU 运算器与控制器RAM 内存&#xff08;存储器&#xff09;Cache 缓存&#xff08;一种技术&#xff09;不属于冯诺依曼体系结构。ROM 磁盘&#xff08;输入输出设备&#xff09;磁盘 既可以从硬盘读取数据也可以向硬盘…

智能数据提取:在严格数据治理与安全标准下的实践路径

一、引言 随着信息技术的飞速发展&#xff0c;数据已成为企业最宝贵的资产之一。然而&#xff0c;数据量的爆炸式增长和数据格式的多样化&#xff0c;使得传统的数据提取方法变得效率低下且难以满足业务需求。智能数据提取技术应运而生&#xff0c;它通过应用人工智能和机器学…

JETBRAINS IDES 分享一个2099通用试用码!DataGrip 2024 版 ,支持一键升级

文章目录 废话不多说上教程&#xff1a;&#xff08;动画教程 图文教程&#xff09;一、动画教程激活 与 升级&#xff08;至最新版本&#xff09; 二、图文教程 &#xff08;推荐&#xff09;Stage 1.下载安装 toolbox-app&#xff08;全家桶管理工具&#xff09;Stage 2 : 下…

了解RFID技术如何改善危化品仓储管理效率

随着科学的发展&#xff0c;我国化工行业也迎来飞速进步的黄金时期&#xff0c;而生产加工快速化的同时也导致一些危险化学品的使用量与存储量不断增加。由于危险化学品种类较多&#xff0c;使用和存储的方法都不一样&#xff0c;还具有易燃、易爆、腐蚀、毒害等特性&#xff0…

win编写bat脚本启动java服务

新建txt&#xff0c;编写&#xff0c;前台启动&#xff0c;出现cmd黑窗口 echo off start java -jar zhoao1.jar start java -jar zhoao2.jar pause完成后&#xff0c;重命名.bat 1、后台启动&#xff0c;不出现cmd黑窗口&#xff0c;app是窗口名称 echo off start "名…

[启明智显技术分享] 在ESP32环境搭建过程中,如果在VS Code中遇到乱码问题应该怎么解决

前言&#xff1a; 【启明智显】专注于HMI&#xff08;人机交互&#xff09;及AIoT&#xff08;人工智能物联网&#xff09;产品和解决方案的提供商&#xff0c;我们深知彩屏显示方案在现代物联网应用中的重要性。为此&#xff0c;我们一直致力于为客户提供彩屏显示方案相关的技…

PCB供电夹子DIY

在刷小红书的时候&#xff0c;看到了清华卓晴教授【https://zhuoqing.blog.csdn.net/】DIY的供电夹子&#xff0c;感觉对于自己DIY PCB的时候供电会比较方便&#xff0c;物料也比较简单&#xff0c;打算复刻一下。 使用物料 1、小夹子&#xff0c;文具店都有卖&#xff0c;选…

【Vim】

一、什么是Vim&#xff1f; Vim 是一个历史悠久的文本编辑器&#xff0c;可以追溯到 qed。 Bram Moolenaar 于 1991 年发布初始版本。Vim 有着悠久的历史;它起源于 Vi 编辑器&#xff08;1976 年&#xff09;&#xff0c;至今仍在开发中。(Vim has a rich history; it origina…

Http文件下载的相关header

Http文件下载的相关header 在HTTP中&#xff0c;用于文件下载的常见响应头&#xff08;response headers&#xff09;包括&#xff1a; Content-Disposition: 用于指示浏览器应该如何处理响应体。在文件下载中&#xff0c;通常设置为 attachment; filename"filename.jpg&…

docker容器与centos宿主机时间一致设置

1、查看宿主机的系统时间 date -R 2、进入到容器中查看容器系统时间 docker exec -it storage /bin/bash date -R 3、查看容器系统时区 cat /etc/timezone 4、查看宿主机所在时区 timedatectl 5、创建容器时间&#xff0c;并退出进入的容器 6、将宿主日期复制到容器内部&…

PPT为何无法复制粘贴?附解决办法!

PPT文件里的内容无法复制&#xff0c;或者复制后无法粘贴&#xff0c;这是怎么回事呢&#xff1f; 这种情况&#xff0c;一般是因为PPT被设置了保护&#xff0c;设置了以“只读方式”打开&#xff0c;就无法进行复制粘贴了。PPT的“只读方式”不同&#xff0c;解决方法也不同&…

520告白好物有哪些?收下这份清单不迷茫!

在这个充满爱意的日子里&#xff0c;你是否正在为如何向心仪的人表达深情而犯愁&#xff1f;别担心&#xff0c;我们为你精心准备了一份520告白好物清单都是一些实用的礼品&#xff0c;为你提供多样化的选择&#xff0c;助你轻松传达爱意&#xff0c;让告白不再迷茫。快来看看吧…