Django采用MVT架构而非MVC:Model负责数据逻辑与数据库交互,View处理请求响应(类似MVC的Controller),Template专注页面渲染。

什么是Django的MVT架构
Django没有采用常见的MVC(Model-View-Controller),而是使用MVT(Model-View-Template)结构。这不只是名字替换,而是职责划分更贴合Web开发实际:模型(Model)负责数据逻辑和数据库交互;视图(View)是处理请求与响应的核心业务逻辑(类似MVC中的Controller);模板(Template)专注页面渲染,不包含复杂逻辑。
Model:定义数据结构与数据库操作
Model是Python类,继承自django.db.models.Model,每个类对应一张数据库表。字段类型(如CharField、DateTimeField)决定数据库列类型和校验规则。
- 定义好Model后,运行
python manage.py makemigrations生成迁移文件,再用python manage.py migrate同步到数据库 - 通过
Model.objects.all()、filter()、get()等方法查询数据,无需写SQL - 支持外键(
ForeignKey)、多对多(ManyToManyField)等关系,Django自动处理关联查询和约束
View:接收请求、处理业务、返回响应
View是函数或类,核心任务是“根据用户请求做什么”。它从URL路由接收参数,调用Model获取或保存数据,再把结果交给Template渲染,或直接返回JSON/重定向等响应。
- 函数式视图(FBV):以
request为第一个参数,返回HttpResponse或其子类(如render()、redirect()) - 类视图(CBV):继承
View、ListView、DetailView等,复用性高,适合列表页、详情页等常见模式 - View不负责HTML拼接——它只准备数据(如字典),由Template完成最终展示
Template:纯展示层,用Django模板语法渲染页面
Template是HTML文件,内嵌Django模板语言(DTL):变量({{ name }})、标签({% for item in list %})、过滤器({{ text|upper }})。它不能执行任意Python代码,确保前后端关注点分离。
立即学习“Python免费学习笔记(深入)”;
- 使用
render(request, 'template.html', context)将上下文数据传入模板 - 支持模板继承:
{% extends "base.html" %}+{% block content %},避免重复代码 - 静态文件(CSS/JS/图片)通过
{% static %}标签引入,需配置STATIC_URL和STATICFILES_DIRS
URL路由:连接View与用户访问地址
URL配置是MVT的“入口开关”。Django用urlpatterns列表匹配请求路径,转发给对应View处理。路径可含参数(如path('article/),由路由自动解析并传入View。
- 主
urls.py通常用include()分发到各App的子路由,保持结构清晰 - 推荐优先使用
path()而非正则url()(已弃用),语义更明确,支持类型转换 - 命名URL(
name='article-detail')配合{% url 'article-detail' pk=1 %},让链接更灵活、可维护










