Web框架开发-Django简介

一、MVC和MTV模型

  • MVC

所谓MVC就是把web应用分为模型(M),控制器(C)和视图(V)三层,他们之间以一种插件式的,松耦合的方式连接在一起,模型负责业务对象与数据库的映射(ORM),视图负责与用户的交互(页面),控制器接受用户的输入调用模型和视图完成用户的请求,其示意图如下所示:

MTV:

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

  • M代表模型(Model):负责业务对象和数据库的关系映射(ORM)
  • T代表模板(Template):负责如何把页面展示给用户(HTML)
  • V代表视图(View):负责业务逻辑,并在适当时候调用Model和Template

除了以上三层之外,还需要一个URL分发器,它的作用是将一个URL的页面请求分发给不同的view处理,view再调用相应的Model和Template,MTV的响应模式如下所示:

一般是用户通过浏览器向我们的服务器发起一个请求(request),这个请求会去访问视图函数,(如果不涉及到数据调用,那么这个时候视图函数返回一个模板也就是一个网页给用户),视图函数调用模型,模型去数据库查找数据,然后逐级返回,视图函数把返回的数据填充到模板中,最后返回网页给用户

二、Django的下载与基本命令

1. 下载django:

|---|-----------------------|
| 1 | pip3 install django |

2. 创建一个django project

|---|---------------------------------------|
| 1 | django-admin.py startproject mysite |

当前目录下会生成mysite的工程,目录结构如下

  • manage.py ----- Django项目里面的工具,通过它可以调用django shell和数据库等。
  • settings.py ---- 包含了项目的默认设置,包括数据库信息,调试标志以及其他一些工作的变量。
  • urls.py ----- 负责把URL模式映射到应用程序。

3、在mysite目录下创建应用

|---|------------------------------------------|
| 1 | python3 manage.py startapp blog(应用名称) |

4、启动django项目

|---|-----------------------------------|
| 1 | python manage.py runserver 8080 |

这样我们的django就启动起来了!当我们访问:http://127.0.0.1:8080/时就可以看到:

三、基于Django实现的一个简单示例

URL控制器

|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 2 3 4 5 6 7 8 9 10 11 12 | from django.contrib import admin from django.urls import path from app01 import views urlpatterns = [ ``path('admin/', admin.site.urls), ``# path('articles/2003/', views.special_case_2003), ``# path('articles/<``int:year``>/', views.year_archive), ``path('articles/<``int:year``>/<``int:month``>/', views.month_archive), ``path('index/', views.index) ] |

视图

|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 2 3 4 5 6 | def index(request): ``now = datetime.datetime.now() ``ctime = now.strftime("%Y-%m-%d %X") ``return render(request, "index.html", {"ctime": ctime}) |

模板

|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 2 3 4 5 6 7 8 9 10 11 | <!``DOCTYPE html> <``html lang="en"> <``head``> ``<``meta charset="UTF-8"> ``<``title``>Title</``title``> </``head``> <``body``> <``h2``>当前时间:{``{ ctime }}</``h2``> </``body``> </``html``> |

执行效果如下:

相关推荐
张拭心2 小时前
Cursor 又偷偷更新,这个功能太实用:Visual Editor for Cursor Browser
前端·人工智能
I'm Jie2 小时前
深入了解 Vue 3 组件间通信机制
前端·javascript·vue.js
用户90443816324603 小时前
90%前端都踩过的JS内存黑洞:从《你不知道的JavaScript》解锁底层逻辑与避坑指南
前端·javascript·面试
CodeCraft Studio4 小时前
文档开发组件Aspose 25.12全新发布:多模块更新,继续强化文档、图像与演示处理能力
前端·.net·ppt·aspose·文档转换·word文档开发·文档开发api
PPPPickup4 小时前
easychat项目复盘---获取联系人列表,联系人详细,删除拉黑联系人
java·前端·javascript
老前端的功夫4 小时前
前端高可靠架构:医疗级Web应用的实时通信设计与实践
前端·javascript·vue.js·ubuntu·架构·前端框架
前端大卫5 小时前
【重磅福利】学生认证可免费领取 Gemini 3 Pro 一年
前端·人工智能
孜燃5 小时前
Flutter APP跳转Flutter APP 携带参数
前端·flutter
脾气有点小暴5 小时前
前端页面跳转的核心区别与实战指南
开发语言·前端·javascript
lxh01135 小时前
最长递增子序列
前端·数据结构·算法