Django-MVT以及Django基础

一.框架

框架是应对某类软件设计问题而产生的,它是由各个软件模块组成的,每个模块都有特定的功能,模块与模块之间通过相互配合来完成软件的开发。

二. MVC 框架

MVC简介

  • MVC的理念: 分工,让专门的人去做专门的事。
  • MVC的核心思想: 解耦。

Web MVC框架模块功能

  • M:Model, 和数据库进行交互。
  • V:View, 产生html页面。
  • C:Controller, 用于接收、处理请求,与M和V进行交互,返回应答。
    如下图所示
    在这里插入图片描述

三.Django框架

3.1Django简介

Django ,遵循MVC思想,但是有自己的一个名词,叫做MVT。

3.2Django中的MVT

  • M:Model,模型, 和MVC中M功能相同,同样是和数据库进行交互。
  • V:View,视图, 相当于MVC中C,接收、处理请求,与M和T进行交互,返回应答。
  • T:Template,模板, 和MVC中V功能相同。
    如下图所示 假定baidu为Django开发
    在这里插入图片描述

3.3Django安装

pip install django
// 指定版本 安装
pip install django==2.2.2

3.4第一个Django项目

  • 建立项目
django-admin startproject mysite
  • 项目目录
.
├── manage.py // django项目的管理文件
└── mysite
    ├── __init__.py     //__init__.py: 说明是一个python包。
    ├── settings.py  //配置文件
    ├── urls.py  //url路由配置
    └── wsgi.py // web服务器和Django交互的接口
  • 创建Django应用(app)
cd mysite //进入django项目中
python manage.py startapp testapp // testapp 为App的名字
// 也可以使用
django-admin startapp testapp 

3.5配置文件 settings

  • 注册应用
INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
#  'testapp',   早期版本使用
     'testapp.apps.TestappConfig',   # 2.0以上版本使用 
]
  • 配置时区和语言环境
LANGUAGE_CODE = 'zh-hans'

TIME_ZONE = 'Asia/Shanghai'
  • 配置templates 目录
TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS': [os.path.join(BASE_DIR, 'templates')],
        'APP_DIRS': True,
        'OPTIONS': {
            'context_processors': [
                'django.template.context_processors.debug',
                'django.template.context_processors.request',
                'django.contrib.auth.context_processors.auth',
                'django.contrib.messages.context_processors.messages',
            ],
        },
    },
]
  • 配置static
STATICFILES_DIRS = (
    os.path.join(BASE_DIR, 'static'),
)
  • 数据库配置
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    }
}

3.6 视图

在Django中,通过浏览器去请求一个页面时,使用视图函数来处理这个请求的,视图函数处理之后,要给浏览器返回页面内容。

视图函数

  • 定义视图函数
    视图函数在views.py中定义。
"""
视图函数必须有一个参数request,进行处理之后,需要返回一个HttpResponse的类对象。
hello world就是返回给浏览器显示的内容。
"""
def index(request):  // request参数必须
	return HttpResponse('hello world')

3.7 url路由

url配置的目的是让建立url和视图函数的对应关系。url配置项定义在urlpatterns的列表中,每一个配置项都调用url函数。
url函数有两个参数,第一个参数是一个正则表达式,第二个是对应的处理动作。

1.X版本配置url时,有两种语法格式:
a) url(正则表达式,视图函数名)
b) url(正则表达式,include(应用中的urls文件))

from django.conf.urls import url
from django.contrib import admin
from testapp import views

urlpatterns = [
    url(r'^admin/', admin.site.urls),
    url(r'^index/', views.index),
 
]

2.x版本使用path更方便

from django.contrib import admin
from django.urls import path
from testapp import views

urlpatterns = [
    path('admin/', admin.site.urls),
    path('index', views.index, name="index" ),
]

正式开发中,在配置url时,首先在项目的urls.py文件中添加配置项时,并不写具体的url和视图函数之间的对应关系,而是包含具体应用的urls.py文件,在应用的urls.py文件中写url和视图函数的对应关系。

以2.2.2版本演示 项目urls

from django.contrib import admin
from django.urls import path, include

urlpatterns = [
    path('admin/', admin.site.urls),
    path('', include('testapp.urls') ),
]

app中urls

from django.urls import path
from testapp import views

urlpatterns = [
    path("index", iviews.index, name='index' ),
]

url和view配置过程

在这里插入图片描述- 1)在项目的urls文件中包含具体应用的urls文件,在具体应用的urls文件中包含具体url和视图的对应关系。

  • 2)url配置项是定义在一个名叫urlpatterns的列表中,其中的每一个元素就是一个配置项,每一个配置项都调用url函数。

3.8 Model

django中内嵌了ORM框架,ORM框架可以将类和数据表进行对应起来,只需要通过类和对象就可以对数据表进行操作。
在Django中主要是设计类:模型类。
ORM另外一个作用:根据设计的类生成数据库中的表。

在应用models.py中设计模型类。

示例

class UserInfo(models.Model):
    username = models.CharField(max_length=24)
    age = models.IntegerField()
    gender = models.BooleanField()
    email = models.EmailField()

生成迁移文件

python manage.py makemigrations

执行迁移文件生成数据表

python mange.py migrate
//生成表名的默认格式:应用名_模型类名小写

基础操作

  • 增加一条数据

第一种方式

 user1 = model.UserInfo()  # 创建一个对象
 user1.username = '张三'
 user1.age = 18
 user1.gender = False
 user1.email = 'zhangsan@test.com'
 user.save() //执行save后,会保存数据到数据表中

第二种方式

user1 = models.UserInfo.objects.create(username='张三', age=18, gender=False,
					 email='zhangsan@test.com')
  • 查询id为1的用户信息
user1 = models.UserInfo.get(id=1)
  • 修改id为1的用户的email
user1 = models.UserInfo.get(id=1)
user1.email = 'zhangsan@abc.com'
user1.save()
  • 删除id为1的用户
user1 = models.UserInfo.get(id=1)
user1.delete()
  • 查询所有用户信息
models.UserInfo.objects.all()
posted @ 2020-04-13 11:57  leafgood  阅读(417)  评论(0编辑  收藏  举报