Django1.11.4框架简介(一)

参考以下内容学习

作者: 哥哥没有错,微信号 墨迹测试开发 Yong

文章目录

整体大纲
在这里插入图片描述

Django1.11.4之基本流程走通

设计模式

MVC

核心思想
解耦
浏览器请求发送给Controller,Controller把需求发给Model,Model返回数据给Controller,Controller把数据传送给View渲染,View返回给浏览器
编程模式
Model(模型)
应用程序中处理数据逻辑的部分
通常模型对象负责在数据库中存取数据
View(视图)
处理数据显示的部分
通常视图是依据模型数据创建的
Controller(控制器)
处理用户交互的部分
负责从视图读取数据,通知用户输入,并向模型发送数据
优点
降低了各功能模块之间的耦合性,方便重构代码,最大程度上实现了代码重用

MTV

概述
本质与MVC没有区别,各组件之间为了保持松耦合关系
编程模式
Model(模型)
负责业务对象与数据库的对象(ORM)
Template(模板)相当于MVC里的View
负责把页面展示给用户
View(视图)相当于MVC里的Controller
负责业务逻辑,并在适当时候调用Model和Template
注意
Django还有一个url分发器,作用是将一个个URL分发给不同的View处理
图解
双击放大
说明:1.用户输入URL,通过URL控制器进行正则匹配,匹配到相应的视图函数,交给视图处理;2.视图交给Model去取数据,Model取完数据返回给视图;3.视图再把需要展示的数据传给模板(就是html页面)

安装 Django1.11.4版本

Django与Python对应版本自行百度

安装步骤

进入终端
输入 pip install Django==1.11.4
验证是否安装成功
进入Python环境
import django
django.get_version()

创建项目

创建目录

打开终端进入刚才创建的目录下

输入 django-admin startproject djangodemo(最后一个是项目名称)

输入 tree . /F 查看目录层级

目录层级

manage.py
一个命令行工具,用于我们和Django的交互
project目录
init.py
空文件,告诉Python这个目录应该被看做一个Python包
settings.py
项目配置文件
urls.py
URL分发器,项目的URL声明
wsgi.py
项目与WSGI兼容的web服务器入口

基本操作

设计表结构

数据库的知识,随意设计就行了
班级表
学生表

配置数据库

Django默认数据库是SQLite
settings.py中,通过DATABASES配置数据库
配置MySQL
用pymysql库
在__init__.py中写入两行代码
import pymysql

pymysql.install_as_MySQLdb()

settings.py中
DATABASES = {
'default': {
    'ENGINE': 'django.db.backends.mysql',
    'NAME': 'djangodemo2',
    'USER': 'root',
    'PASSWORD': '123456',
    'HOST': 'localhost',
    'PORT': '3306',
}

}

####### NAME中填数据库名

####### USER和PASSWORD分别是用户名和密码

####### HOST为数据库服务器ip,直接填本地主机

####### PORT为3306默认端口

创建应用

一个项目可以创建多个应用,每个应用负责一种业务
打开终端,进入项目目录,结构为:
│ manage.py

└─djangodemo2
settings.py
urls.py
wsgi.py
init.py

执行python manage.py startapp myApp
创建一个名为myApp的应用
myApp目录说明
admin.py
站点配置
models.py
模型
views.py
视图

激活应用(将应用配置到项目中)

settings.py文件中,将myApp加入到INSTALLED_APPS中
# Application definition

INSTALLED_APPS = [
‘django.contrib.admin’,
‘django.contrib.auth’,
‘django.contrib.contenttypes’,
‘django.contrib.sessions’,
‘django.contrib.messages’,
‘django.contrib.staticfiles’,
‘myApp’
]

定义模型(对接数据库)

一个数据库表对应一个模型
在models.py中定义
from django.db import models
模型类要继承models.Model类
class Grades(models.Model):
name = models.CharField(max_length=20)
date = models.DateTimeField()
girl_num = models.IntegerField()
boy_num = models.IntegerField()
isDelete = models.BooleanField(default=False)

# 更改Grades.objects.all()的输出内容
def __str__(self):
    return "%s-%d-%d" % (self.name, self.girl_num, self.boy_num)

class Students(models.Model):
name = models.CharField(max_length=20)
gender = models.BooleanField(default=True)
age = models.IntegerField()
contend = models.CharField(max_length=20)
isDelete = models.BooleanField(default=False)
# 外键
grade = models.ForeignKey(“Grades”)

两个类对应库中的两个表,字段名与老师的略有不同
说明:不需要定义主键,主键在生成表时自动添加,并默认值自动添加

生成数据表

生成迁移文件
终端中执行: python manage.py makemigrations
myApp的目录migrations下生成一个迁移文件
执行迁移
终端中执行: python manage.py migrate
数据库中会生成一系列表
如果重新迁移的话,需要删除0001.initial.py文件,把数据库也一块删除,然后再生成迁移文件,再迁移
新增一张表的话不需要重新迁移,直接生成0002的迁移文件,再执行迁移即可
修改原表的字段的话,需要重新迁移

测试操作数据

进入python shell
执行python manage.py shell
引入一些包
from myApp.models import Grades, Students

from django.utils import timezone
from datatime import *

查询班级表所有数据
Grades.objects.all()
添加数据
本质:创建一个模型类的对象实例
grade1 = Grades()
创建一个空实例
grade1.name = ‘python’
名字
grade1.date = datetime(yaer=2020, month=4, day=23)
日期
grade1.save()
将刚才创建的grade1实例传给数据库,创建一条数据
重写类的__str__函数使之更好地显示数据
class Grades(models.Model):

####### name = models.CharField(max_length=20)

####### date = models.DateTimeField()

####### girl_num = models.IntegerField()

####### boy_num = models.IntegerField()

####### isDelete = models.BooleanField(default=False)

####### # 更改Grades.objects.all()的输出内容

####### def str(self):

######## return “%s-%d-%d” % (self.name, self.girl_num, self.boy_num)

查看某个数据
Grades.objects.all()
查询所有
类名.objects.get(pk=2)
查询id为2的那一条数据
分支主题
修改数据
模型对象.属性 = 新值
grade.name = ‘c++’
模型对象.save()
grade.save()
删除数据(物理删除)
g = Grades.objects.get(pk=2)
g.delete()
关联对象
stu = Students()
stu.name = ‘zcz’
获得关联对象的集合
需求:获取某个班级的所有学生
类名.关联的类名小写_set.all()

####### grade1.students_set.all()

######## students_set是自带的方法

需求:创建某个人,属于某个班级
stu3 = grade1.setudents_set.create(name=u’曾志伟’, gender=True, …)
会直接添加到数据库,不用再进行save()

启动服务器

格式

python manage.py runserver ip:port
ip不写代表本机ip
port不写默认是8000

说明

Python写的轻量级web服务器,仅在开发测试时使用

启动

打开终端没进入项目目录
python manage.py runserver
别忘了启动数据库
浏览器输入 127.0.0.1:8000检查

分支主题

Admin站点管理

更好的管理数据库的数据,相当于一个后台管理系统

概述

内容发布
负责添加、修改、删除数据
公告访问

配置Admin应用

在settings.py中的INSTALLED_APPS中添加django.contrib.admin
默认已经添加

创建管理员用户

python manage.py createsuperuser
输入账号密码
浏览器127.0.0.1:8000/admin进入

汉化

settings.py文件
LANGUAGE_CODE = ‘zh-Hans’

TIME_ZONE = ‘Asia/Shanghai’

管理数据表

修改admin.py文件
引入models中的类
from .models import Grades, Students
添加注册
admin.site.register(Grades)

admin.site.register(Students)

自定义管理页面
定义类class GradesAdmin(admin.ModelAdmin):
列表页属性
list_display = [‘pk’, ‘name’, ‘date’, ‘girl_num’, ‘boy_num’, ‘isDelete’]

####### 修改页面显示的字段

list_filter = [‘name’]

####### 过滤器,在页面右侧

search_fields = [‘name’]

####### 搜索框

list_per_page = 5

####### 每页最多显示多少条数据

添加、修改页属性
fields = [‘girl_num’, ‘boy_num’, ‘name’, ‘date’, ‘isDelete’]

####### 规定属性的先后顺序

fieldsets = [

(‘num’, {‘fields’: [‘girl_num’, ‘boy_num’]}),
(‘base’, {‘fields’: [‘name’, ‘date’, ‘isDelete’]}),
]

####### 给属性分组

注意:fields和fieldsets不能同时使用
关联对象
需求:在创建一个班级的时候可以同时添加几个学生

####### class StudentsInfo(admin.TabularInline):

######## model = Students

######## extra = 0

####### class StudentsInfo(admin.StackedInline):

######## 和上一个排版不一样

####### class GradesAdmin(admin.ModelAdmin):

######## inlines = [StudentsInfo]

布尔值显示问题
写函数
def sex(self):
if self.gender:
    return '男'
else:
    return '女'

设置页面列的名称

sex.short_description = ‘性别’
list_display = [‘pk’, ‘name’, ‘age’, sex, ‘contend’, ‘grade’, ‘isDelete’]

执行动作的位置问题
actions_on_bottom = True

actions_on_top = False

使用装饰器完成注册
@admin.register(Students)

class StudentsAdmin(admin.ModelAdmin):

分支主题

视图的基本使用

概述

在django中,视图对web请求进行回应
视图就是一个Python函数, 在views.py文件中定义

定义视图

from django.http import HttpResponse
def index(request):
return HttpResponse('zcz is a goood boy. ')

配置url

修改project目录下的urls.py文件
from django.conf.urls import url, include

from django.contrib import admin

urlpatterns = [
url(r’^admin/’, admin.site.urls),
url(r’^’, include(‘myApp.urls’)),

]

在myApp应用目录下创建一个urls.py文件
from django.conf.urls import url

from . import views

urlpatterns = [
url(r’^KaTeX parse error: Undefined control sequence: \d at position 27: …dex), url(r'^(\̲d̲+)/’, views.detail),
url(r’^grades/ ′ , v i e w s . g r a d e s ) , u r l ( r ′ s t u d e n t s / ', views.grades), url(r'^students/ ,views.grades),url(rstudents/’, views.students),
url(r’^grades/(\d+)/$’, views.get_student_id),
]

模板的基本使用

概述

模板就是HTML页面,可以根据视图传过来的数据对页面进行填充

创建模板

新建templates文件夹
在templates中新建myApp文件夹

配置模板路径

修改settings.py文件下的TEMPLATES
‘DIRS’: [os.path.join(BASE_DIR, ‘templates’)],

定义grades.html和students.html模板

模板语法
{{ 输出值,可以使变量,可以使对象.属性 }}
{% 执行代码 %}

http://127.0.0.1:8000/grades

写grades.html模板
{% for grade in grades %}
  • {{ grade.name }}
  • {% endfor %}
    定义视图
    from .models import Grades, Students

    def grades(request):
    # 去模型里取数据
    grades_list = Grades.objects.all()
    # 将数据传递给模板, 模板再渲染页面, 将渲染好的页面返回给浏览器
    return render(request, ‘myApp/grades.html’, {‘grades’: grades_list})

    配置URL
    url(r’^grades/$’, views.grades),
    说明:代码只有部分,全代码仍需要去看视频
    流程总结
    写模板,也就是HTML页面
    页面要与数据库交互,因此要定义视图
    视图负责去模型中取得相应的数据(因为模型负责和数据库对接,所以要拿数据库的数据必须经过模型)
    视图在模型中取得了相应的数据,再返回给模板渲染

    点击班级,显示对应班级的所有学生

    定义视图
    def get_student_id(request, num):
    grade = Grades.objects.get(pk=num)

    ####### 获得对应的班级对象

    student_list = grade.students_set.all()

    ####### 获得该班级的学生列表

    return render(request, ‘myApp/students.html’, {‘students’: student_list})
    配置url
    url(r’^grades/(\d+)/$’, views.get_student_id),
    流程解析
    点击grades.html页面的超链接,观察地址栏,可以看到会返回类似于localhost:8000/grades/1的地址,所以需要配置相应的url
    而数据的处理需要交给views层,所以需要定义相对应的视图
    需要注意,虽然地址栏是grades/1,但是显示的是students.html的内容,原因是视图返回了myApp/students.html以及相对应的学生列表
    说明:代码仍旧不全,全代码还请去看视频

    流程梳理

    创建工程

    执行 dijango-admin startproject project

    创建项目

    执行 python manage.py startapp myApp

    激活项目

    修改 settings.py中的INSTALLED_APPS

    配置数据库

    修改__init__.py,引入pymysql包
    修改settings.py文件中的DATABASES

    创建模型类

    在项目目录下的models.py文件中

    生成迁移文件

    执行 python manage.py makemigrations

    执行迁移

    执行 python manage.py migrate

    配置ADMIN站点

    创建模板目录/项目模板目录

    在settings.py文件的TEMPLATES中配置模板路径

    在project下修改urls.py

    在项目目录下创建urls.py

    Django1.11.4之基本流程走通
    	设计模式
    		MVC
    			核心思想
    				解耦
    			浏览器请求发送给Controller,Controller把需求发给Model,Model返回数据给Controller,Controller把数据传送给View渲染,View返回给浏览器
    			编程模式
    				Model(模型)
    					应用程序中处理数据逻辑的部分
    					通常模型对象负责在数据库中存取数据
    				View(视图)
    					处理数据显示的部分
    					通常视图是依据模型数据创建的
    				Controller(控制器)
    					处理用户交互的部分
    					负责从视图读取数据,通知用户输入,并向模型发送数据
    			优点
    				降低了各功能模块之间的耦合性,方便重构代码,最大程度上实现了代码重用
    		MTV
    			概述
    				本质与MVC没有区别,各组件之间为了保持松耦合关系
    			编程模式
    				Model(模型)
    					负责业务对象与数据库的对象(ORM)
    				Template(模板)相当于MVC里的View
    					负责把页面展示给用户
    				View(视图)相当于MVC里的Controller
    					负责业务逻辑,并在适当时候调用Model和Template
    			注意
    				Django还有一个url分发器,作用是将一个个URL分发给不同的View处理
    			图解
    				双击放大
    				说明:1.用户输入URL,通过URL控制器进行正则匹配,匹配到相应的视图函数,交给视图处理;2.视图交给Model去取数据,Model取完数据返回给视图;3.视图再把需要展示的数据传给模板(就是html页面)
    	安装 Django1.11.4版本
    		Django与Python对应版本自行百度
    		安装步骤
    			进入终端
    			输入 pip install Django==1.11.4
    			验证是否安装成功
    				进入Python环境
    				import django
    				django.get_version()
    	创建项目
    		创建目录
    		打开终端进入刚才创建的目录下
    		输入  django-admin startproject djangodemo(最后一个是项目名称)
    		输入   tree .  /F    查看目录层级
    		目录层级
    			manage.py
    				一个命令行工具,用于我们和Django的交互
    			project目录
    				__init__.py
    					空文件,告诉Python这个目录应该被看做一个Python包
    				settings.py
    					项目配置文件
    				urls.py
    					URL分发器,项目的URL声明
    				wsgi.py
    					项目与WSGI兼容的web服务器入口
    	基本操作
    		设计表结构
    			数据库的知识,随意设计就行了
    			班级表
    			学生表
    		配置数据库
    			Django默认数据库是SQLite
    			settings.py中,通过DATABASES配置数据库
    			配置MySQL
    				用pymysql库
    				在__init__.py中写入两行代码
    					import pymysql\npymysql.install_as_MySQLdb()
    				settings.py中
    					DATABASES = {\n	'default': {\n	    'ENGINE': 'django.db.backends.mysql',\n	    'NAME': 'djangodemo2',\n	    'USER': 'root',\n	    'PASSWORD': '123456',\n	    'HOST': 'localhost',\n	    'PORT': '3306',\n	}\n}
    						NAME中填数据库名
    						USER和PASSWORD分别是用户名和密码
    						HOST为数据库服务器ip,直接填本地主机
    						PORT为3306默认端口
    		创建应用
    			一个项目可以创建多个应用,每个应用负责一种业务
    			打开终端,进入项目目录,结构为:
    				│  manage.py\n└─djangodemo2\n	   settings.py\n	   urls.py\n	   wsgi.py\n	   __init__.py
    			执行python manage.py startapp myApp
    				创建一个名为myApp的应用
    			myApp目录说明
    				admin.py
    					站点配置
    				models.py
    					模型
    				views.py
    					视图
    		激活应用(将应用配置到项目中)
    			settings.py文件中,将myApp加入到INSTALLED_APPS中
    				# Application definition\n\nINSTALLED_APPS = [\n	'django.contrib.admin',\n	'django.contrib.auth',\n	'django.contrib.contenttypes',\n	'django.contrib.sessions',\n	'django.contrib.messages',\n	'django.contrib.staticfiles',\n	'myApp'\n]
    		定义模型(对接数据库)
    			一个数据库表对应一个模型
    			在models.py中定义
    				from django.db import models
    				模型类要继承models.Model类
    				class Grades(models.Model):\n	name = models.CharField(max_length=20)\n	date = models.DateTimeField()\n	girl_num = models.IntegerField()\n	boy_num = models.IntegerField()\n	isDelete = models.BooleanField(default=False)\n\n	# 更改Grades.objects.all()的输出内容\n	def __str__(self):\n	    return "%s-%d-%d" % (self.name, self.girl_num, self.boy_num)\n\n\nclass Students(models.Model):\n	name = models.CharField(max_length=20)\n	gender = models.BooleanField(default=True)\n	age = models.IntegerField()\n	contend = models.CharField(max_length=20)\n	isDelete = models.BooleanField(default=False)\n	# 外键\n	grade = models.ForeignKey("Grades")
    					两个类对应库中的两个表,字段名与老师的略有不同
    			说明:不需要定义主键,主键在生成表时自动添加,并默认值自动添加
    		生成数据表
    			生成迁移文件
    				终端中执行:  python manage.py makemigrations 
    					myApp的目录migrations下生成一个迁移文件
    			执行迁移
    				终端中执行: python manage.py migrate
    					数据库中会生成一系列表
    			如果重新迁移的话,需要删除0001.initial.py文件,把数据库也一块删除,然后再生成迁移文件,再迁移
    			新增一张表的话不需要重新迁移,直接生成0002的迁移文件,再执行迁移即可
    			修改原表的字段的话,需要重新迁移
    		测试操作数据
    			进入python shell
    				执行python manage.py shell
    			引入一些包
    				from myApp.models import Grades, Students\nfrom django.utils import timezone\nfrom datatime import *
    			查询班级表所有数据
    				Grades.objects.all()
    			添加数据
    				本质:创建一个模型类的对象实例
    				grade1  = Grades()
    					创建一个空实例
    				grade1.name = 'python'
    					名字
    				grade1.date = datetime(yaer=2020, month=4, day=23)
    					日期
    				grade1.save()
    					将刚才创建的grade1实例传给数据库,创建一条数据
    				重写类的__str__函数使之更好地显示数据
    					class Grades(models.Model):
    						name = models.CharField(max_length=20)
    						date = models.DateTimeField()
    						girl_num = models.IntegerField()
    						boy_num = models.IntegerField()
    						isDelete = models.BooleanField(default=False)
    						# 更改Grades.objects.all()的输出内容
    						def __str__(self):
    							return "%s-%d-%d" % (self.name, self.girl_num, self.boy_num)
    			查看某个数据
    				Grades.objects.all()
    					查询所有
    				类名.objects.get(pk=2)
    					查询id为2的那一条数据
    				分支主题
    			修改数据
    				模型对象.属性 = 新值
    					grade.name = 'c++'
    				模型对象.save()
    					grade.save()
    			删除数据(物理删除)
    				g = Grades.objects.get(pk=2)
    				g.delete()
    			关联对象
    				stu = Students()
    				stu.name = 'zcz'
    				......
    				获得关联对象的集合
    					需求:获取某个班级的所有学生
    					类名.关联的类名小写_set.all()
    						grade1.students_set.all()
    							students_set是自带的方法
    				需求:创建某个人,属于某个班级
    					stu3 = grade1.setudents_set.create(name=u'曾志伟', gender=True, ......)
    					会直接添加到数据库,不用再进行save()
    	启动服务器
    		格式
    			python manage.py runserver ip:port
    			ip不写代表本机ip
    			port不写默认是8000
    		说明
    			Python写的轻量级web服务器,仅在开发测试时使用
    		启动
    			打开终端没进入项目目录
    			python manage.py runserver
    			别忘了启动数据库
    			浏览器输入  127.0.0.1:8000检查
    		分支主题
    	Admin站点管理
    		更好的管理数据库的数据,相当于一个后台管理系统
    		概述
    			内容发布
    				负责添加、修改、删除数据
    			公告访问
    		配置Admin应用
    			在settings.py中的INSTALLED_APPS中添加django.contrib.admin
    				默认已经添加
    		创建管理员用户
    			python manage.py createsuperuser
    			输入账号密码
    			浏览器127.0.0.1:8000/admin进入
    		汉化
    			settings.py文件
    				LANGUAGE_CODE = 'zh-Hans'\n\nTIME_ZONE = 'Asia/Shanghai'
    		管理数据表
    			修改admin.py文件
    				引入models中的类
    					from .models import Grades, Students
    				添加注册
    					admin.site.register(Grades)\nadmin.site.register(Students)
    			自定义管理页面
    				定义类class GradesAdmin(admin.ModelAdmin):
    				列表页属性
    					list_display = ['pk', 'name', 'date', 'girl_num', 'boy_num', 'isDelete']
    						修改页面显示的字段
    					list_filter = ['name']
    						过滤器,在页面右侧
    					search_fields = ['name']
    						搜索框
    					list_per_page = 5
    						每页最多显示多少条数据
    				添加、修改页属性
    					fields = ['girl_num', 'boy_num', 'name', 'date', 'isDelete']
    						规定属性的先后顺序
    					fieldsets = [\n('num', {'fields': ['girl_num', 'boy_num']}),\n('base', {'fields': ['name', 'date', 'isDelete']}),\n]
    						给属性分组
    					注意:fields和fieldsets不能同时使用
    				关联对象
    					需求:在创建一个班级的时候可以同时添加几个学生
    						class StudentsInfo(admin.TabularInline):
    							model = Students
    							extra = 0
    						class StudentsInfo(admin.StackedInline):
    							和上一个排版不一样
    						class GradesAdmin(admin.ModelAdmin):
    							inlines = [StudentsInfo]
    				布尔值显示问题
    					写函数
    					def sex(self):\n	if self.gender:\n	    return '男'\n	else:\n	    return '女'\n# 设置页面列的名称\nsex.short_description = '性别'\nlist_display = ['pk', 'name', 'age', sex, 'contend', 'grade', 'isDelete']
    				执行动作的位置问题
    					actions_on_bottom = True\nactions_on_top = False
    				使用装饰器完成注册
    					@admin.register(Students)\nclass StudentsAdmin(admin.ModelAdmin):
    				分支主题
    	视图的基本使用
    		概述
    			在django中,视图对web请求进行回应
    			视图就是一个Python函数, 在views.py文件中定义
    		定义视图
    			from django.http import HttpResponse
    			def index(request):
    				return HttpResponse('zcz is a goood boy. ')
    		配置url
    			修改project目录下的urls.py文件
    				from django.conf.urls import url, include\nfrom django.contrib import admin\n\n\nurlpatterns = [\n	url(r'^admin/', admin.site.urls),\n	url(r'^', include('myApp.urls')),\n\n]
    			在myApp应用目录下创建一个urls.py文件
    				from django.conf.urls import url\n\nfrom . import views\n\nurlpatterns = [\n	url(r'^$', views.index),\n	url(r'^(\d+)/$', views.detail),\n	url(r'^grades/$', views.grades),\n	url(r'^students/$', views.students),\n	url(r'^grades/(\d+)/$', views.get_student_id),\n]
    	模板的基本使用
    		概述
    			模板就是HTML页面,可以根据视图传过来的数据对页面进行填充
    		创建模板
    			新建templates文件夹
    				在templates中新建myApp文件夹
    		配置模板路径
    			修改settings.py文件下的TEMPLATES
    				'DIRS': [os.path.join(BASE_DIR, 'templates')],
    		定义grades.html和students.html模板
    			模板语法
    				{{ 输出值,可以使变量,可以使对象.属性 }}
    				{% 执行代码 %}
    		http://127.0.0.1:8000/grades
    			写grades.html模板
    				{% for grade in grades %}\n<li>\n	<a href="#">{{ grade.name }}</a>\n</li>\n{% endfor %}
    			定义视图 
    				from .models import Grades, Students\ndef grades(request):\n	# 去模型里取数据\n	grades_list = Grades.objects.all()\n	# 将数据传递给模板, 模板再渲染页面, 将渲染好的页面返回给浏览器\n	return render(request, 'myApp/grades.html', {'grades': grades_list})
    			配置URL 
    				url(r'^grades/$', views.grades),
    			说明:代码只有部分,全代码仍需要去看视频
    			流程总结
    				写模板,也就是HTML页面
    				页面要与数据库交互,因此要定义视图
    				视图负责去模型中取得相应的数据(因为模型负责和数据库对接,所以要拿数据库的数据必须经过模型)
    				视图在模型中取得了相应的数据,再返回给模板渲染
    		点击班级,显示对应班级的所有学生
    			定义视图
    				def get_student_id(request, num):
    					grade = Grades.objects.get(pk=num)
    						获得对应的班级对象
    					student_list = grade.students_set.all()
    						获得该班级的学生列表
    					return render(request, 'myApp/students.html', {'students': student_list})
    			配置url
    				url(r'^grades/(\d+)/$', views.get_student_id),
    			流程解析
    				点击grades.html页面的超链接,观察地址栏,可以看到会返回类似于localhost:8000/grades/1的地址,所以需要配置相应的url
    				而数据的处理需要交给views层,所以需要定义相对应的视图
    				需要注意,虽然地址栏是grades/1,但是显示的是students.html的内容,原因是视图返回了myApp/students.html以及相对应的学生列表
    			说明:代码仍旧不全,全代码还请去看视频
    	流程梳理
    		创建工程
    			执行   dijango-admin startproject project
    		创建项目
    			执行  python manage.py startapp myApp
    		激活项目
    			修改 settings.py中的INSTALLED_APPS
    		配置数据库
    			修改__init__.py,引入pymysql包
    			修改settings.py文件中的DATABASES
    		创建模型类
    			在项目目录下的models.py文件中
    		生成迁移文件
    			执行 python manage.py makemigrations
    		执行迁移
    			执行  python manage.py migrate
    		配置ADMIN站点
    		创建模板目录/项目模板目录
    		在settings.py文件的TEMPLATES中配置模板路径
    		在project下修改urls.py
    		在项目目录下创建urls.py
    
    
    
    

    链接:https://pan.baidu.com/s/1ZAV4lmCxfR_7nFYIgG3UKQ

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Young_svg

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值