PythonDjango基础教程_模型视图模板完整项目实战

Django博客项目需按MTV模式串联模型、视图与模板:一、在models.py定义Article模型并迁移数据库;二、视图函数查数据后用render传入模板;三、模板用{{}}和{% %}语法渲染,推荐继承base.html;四、通过urls.py配置路由,注意命名空间与路径参数解析。

用 Django 搭建一个完整项目,核心就是把 模型(Model)视图(View)模板(Template) 三者串起来——也就是常说的 MTV 模式。下面以一个简单的「博客系统」为例,带你从零跑通整个流程,不绕弯、不堆概念,只讲关键步骤和容易踩的坑。

一、定义模型:告诉 Django 数据长什么样

models.py 里写类,每个类对应数据库中一张表。比如博客文章:

  • CharField 存标题,加 max_length=200 防止超长
  • TextField 存正文,不用限制长度
  • DateTimeField(auto_now_add=True) 自动记录发布时间
  • 别忘了运行 python manage.py makemigrationspython manage.py migrate 让数据库同步

二、编写视图:决定用户看到什么内容

视图函数接收请求,查数据,再把结果传给模板。例如首页展示所有文章:

  • 导入模型:from .models import Article
  • 查数据:articles = Article.objects.all()
  • render() 把数据和模板拼在一起:return render(request, 'blog/index.html', {'articles': articles})
  • 注意:别直接用 HttpResponse 返回纯文本,那样没法套样式和结构

三、设计模板:用 HTML 把数据“画”出来

模板放在 templates/ 文件夹下,用 Django 模板语法渲染动态内容:

  • {{ article.title }} 显示单个字段
  • {% for article in articles %}...{% endfor %} 遍历列表
  • {% url 'article_detail' pk=article.pk %} 生成带参数的 URL,前提是已在 urls.py 中配置命名路由
  • 建议用 {% extends 'base.html' %} 做模板继承,避免重复写 header/footer

四、连通路由:让网址能找得到视图

urls.py 中把 URL 路径和视图函数关联起来:

  • urls.py(项目级)用 include() 引入应用路由
  • 应用内的 urls.py 写具体映射,比如 path('', views.index, name='index')
  • 路径参数用 这种写法,Django 会自动转换并传给视图函数
  • 别漏掉 app_name = 'blog',否则命名空间 URL 可能出错

跑起来之后,访问 http://127.0.0.1:8000/ 就能看到文章列表,点进去看详情页,整个流程就闭环了。后续加后台管理、用户登录、富文本编辑,都是在这个骨架上一层层添砖加瓦。