视图函数的使用
1) 定义视图函数
视图函数定义在views.py中
例:
def index(request):
# 返回应答
return HttpResponse('hello world')
视图函数必须有一个参数request,进行处理之后,需要返回一个HttpResponse的类对象,hello world就是返回给浏览器显示的内容,在使用HttpResponse的类对象之前,需要导入
from django.http import HttpResponse
2) 进行url配置
url配置的目的是让建立url和视图函数的对应关系。url配置项定义在urlpatterns的列表中,每一个配置项都调用url函数
url函数有两个参数,第一个参数是一个正则表达式,第二个是对应的处理动作
配置url时,有两种语法格式:
a) url(正则表达式,视图函数名)
b) url(正则表达式,include(应用中的urls文件))
在配置url时,首先在项目的urls.py文件中添加配置项时,并不写具体的url和视图函数之间的对应关系,而是包含具体应用的urls.py文件,在应用的urls.py文件中写url和视图函数的对应关系
在test/settings.py中通过ROOT_URLCONF指定url配置,默认已经有此配置
打开test/urls.py可以看到默认配置
在test/urls.py中进行包含配置,在各自应用中创建具体配置
url匹配的过程
在项目的urls.py文件中包含具体应用的urls.py文件,应用的urls.py文件中写url和视图函数的对应关系
项目urls配置如下:
应用urls配置如下:
我们先假设,当用户输入如http://127.0.0.1:8000/aindex,浏览器会去除域名和最前面的/,剩下aindex,然后把aindex字符串在项目的urls文件中进行匹配,配置成功之后,去除最前面的a,那剩下的index字符串继续到应用的urls文件中(也就是我们的包含函数下的路径)进行正则匹配,匹配成功之后执行视图函数index,index视图函数返回内容 ‘hello world’ 给浏览器来显示页面
语法
url对象,被定义在django.conf.urls包中,有两种语法结构:
语法一:包含,一般在自定义应用中创建一个urls.py来定义url
这种语法用于test/urls.py中,目的是将应用的urls配置到应用内部,数据更清晰并且易于维护
url(正则,include('应用.urls'))
如示例在test/urls.py文件,包含booktest中的urls
url(r'^',include('booktest.urls')),
在booktest目录下创建urls.py文件
语法二:定义,指定URL和视图函数的对应关系
在应用内部创建urls.py文件,指定请求地址与视图的对应关系
url(正则,'视图函数名称')
1)如示例在booktest/urls.py中创建首页的url,代码如下
from django.conf.urls import url
from booktest import views
urlpatterns=[
url(r'^$',views.index),
]
2)如示例在booktest/views.py中创建视图index
from django.shortcuts import render
from django.http import HttpResponse
def index(request):
return HttpResponse("hello world")
说明1:正则部分推荐使用r,表示字符串不转义,这样在正则表达式中使用\只写一个就可以
说明2:不能在开始加反斜杠,推荐在结束加反斜杠
正确示范:index/
正确示范:index
错误示范:/index
错误示范:/index/