视图
1. 视图的功能
接收请求,进行处理,与M和T进行交互,返回应答。
返回html内容 HttpResponse,也可能重定向 redirect,还可以返回json数据。
1.1创建案列项目
1、创建项目:django-admin startproject demo3
2、创建应用,python manage.py startapp app1
3、注册应用 ,打开demo3下的settings文件,设置如下信息
INSTALLED_APPS = ( 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'app1', )
4、配置数据库,先在项目目录下面的__init__
文件添加如下代码
import pymysql pymysql.install_as_MySQLdb()
再在demo3下的settings文件,设置如下信息
DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME': 'demo3', # 指定数据库名字 'USER':'root', 'PASSWORD':'mysql', 'PORT':3306, 'HOST':'localhost' } }
5、创建模型类,
在应用目录下的models.py
定义如下代码
class NewsInfo(models.Model): title = models.CharField(max_length=30) content = models.TextField()
6、生成迁移,python manage.py makemigrations
7、执行迁移、python manage.py migrtion
8、新建模板文件、
在项目目录下新建一个名为tamplates的文件夹,在该文件夹下面新建一个和应用同名的文件夹app1,
9、修改模板路径
设置查找模板的路径:打开settings.py文件,设置TEMPLATES的DIRS值
'DIRS': [os.path.join(BASE_DIR, 'templates')],
1.2. 视图函数使用
视图就是一个python函数,被定义在"应用/views.py"文件中。 使用视图时需要进行两方面操作,两个操作不分先后。
1)在"应用/views.py"中定义视图,
视图 函数request参数必须有。返回的是一个HttpRequest类型的对象。参数名可以变化。
在app1/views.py中定义视图函数index:
from django.shortcuts import render # Create your views here. from django.http import HttpResponse def index(request): return HttpResponse('<h1>个是新定义的视图index<h1>')
2)配置URLconf,将视图函数和url对应起来。
1) 在项目的urls文件中包含具体应用的urls文件,在具体应用的urls文件中包含具体url和视图的对应关系。
2) url配置项是定义在一个名叫urlpatterns的列表中,其中的每一个元素就是一个配置项,每一个配置项都调用url函数。
在项目目录下的urls.py中编辑加入如下代码:
from django.conf.urls import include, url from django.contrib import admin urlpatterns = [ url(r'^admin/', include(admin.site.urls)), url(r'^', include('app1.urls')), #这句代码是新加入的,包含app1应用中的urls文件 ]
在应用目录下创建urls.py文件并编辑其内容如下:
from django.conf.urls import url #导入url函数 from .views import * #导入视图模块 urlpatterns = [ url(r'^$',index), #建立url和index视图函数的关联 ]
1.3启动服务器,
启动项目命令python manage.py runserver
并通过浏览器访问定义的视图页面
2. url匹配的过程
用户通过在浏览器的地址栏中输入网址请求网站,对于Django开发的网站,由哪一个视图进行处理请求,是由url匹配找到的。
2.1、配置
1、在项目目录下的/settings.py中通过ROOT_URLCONF指定url配置,默认已经有此配置。
ROOT_URLCONF = 'demo3.urls'
2、打开demo3/urls.py可以看到默认配置
from django.conf.urls import url,include urlpatterns = [ url(r'admin/',include(admin.site.urls)), ]
注意点
-
在项目目录下的urls.py中进行包含配置,在各自应用中创建具体配置。
-
在urls里面定义urlpatterns列表,存储url()对象,这个名称是固定的。urlpatterns中的每个正则表达式在第一次访问它们时被编译,这使得运行很快
2.2、语法
url()对象,被定义在django.conf.urls包中,有两种语法结构:
语法一:包含,一般在自定义应用中创建一个urls.py来定义url。
这种语法用于demo3/urls.py中,目的是将项目的urls配置到应用内部,数据更清晰并且易于维护。
url(正则,include('应用.urls'))
1)如示例在test3/urls.py文件,包含app1中的urls。
url(r'^',include('app1.urls')),
语法二:定义,指定URL和视图函数的对应关系。
在应用内部创建urls.py文件,指定请求地址与视图的对应关系。
url(正则,'视图函数名称')
1)如示例在app1/urls.py中创建首页的url,代码如下
from django.conf.urls import url from .views import * urlpatterns = [ url(r'^$',index), url(r'^index$',index) ]
2)如示例在app1/views.py中创建视图index
from django.shortcuts import render from django.http import HttpResponse def index(requuest): return HttpResponse('<h1>这个是新定义的视图index<h1>')
说明1:正则部分推荐使用r,表示字符串不转义,这样在正则表达式中使用\只写一个就可以。
说明2:不能在开始加反斜杠,推荐在结束加反斜杠。
正确:index/ 正确:index 错误:/index 错误:/index/
2.3、捕获url中的参数
请求的url被看做是一个普通的python字符串,进行匹配时不包括域名、get或post参数。 如请求地址如下:
http://172.0.0.1:8000/index1/
1)去除掉域名和参数部分,并将最前面的/去除后,只剩下如下部分与正则匹配。
index/
2)打开app1/urls.py文件,定义与这个地址匹配的url如下:
url(r'^index\d+/$',show1),
3)在app1/views.py中创建视图show。
def show(request): return HttpResponse('这个是show视图')
4)启动服务器,输入上面的网址,浏览器中效果如下图
http://172.0.0.1:8000/index1/
可以在匹配过程中从url中捕获参数,每个捕获的参数都作为一个普通的python字符串传递给视图。
获取值需要在正则表达式中使用小括号,分为两种方式:
-
位置参数
-
关键字参数
注意:两种参数的方式不要混合使用,在一个正则表达式中只能使用一种参数方式。
方式一:位置参数
直接使用小括号,通过位置参数传递给视图。
1)为了提取参数,修改上面的正则表达式如下:
url(r'^index(\d+)/$',views.show_arg),
2)修改视图show如下:
def show(request,num): return HttpResponse('这个是show返回的页面,index后面的num:%s'%num)
3)刷新浏览器页面,效果如下图:
方式二:关键字参数
在正则表达式部分为组命名。
1)修改正则表达式如下:
其中?P部分表示为这个参数定义的名称为id,可以是其它名称,起名做到见名知意。
url(r'^index(?P<name1>\d+)/$',show),
2)修改视图show如下:
注意:视图show此时必须要有