Django框架视图介绍与使用详解
作者:笑-笑-生
本文实例讲述了Django框架视图介绍与使用。分享给大家供大家参考,具体如下:
视图
- 视图:即一个python函数,可以叫 视图函数,或者简称 视图,定义在 应用/views.py 文件中。
- 作用:接收并处理请求,调用M和T,响应请求(返回HttpResponse或其子类)
- 每一个用户请求,都对应着一个视图(和url地址),由视图处理请求后,再返回html页面内容给浏览器显示。
URL配置及匹配
作用:建立url地址和视图函数的对应关系,当用户请求某个url地址时,让django能找到对应的视图函数进行处理。
配置url:
在应用下创建urls.py,然后在项目下的urls.py文件中包含进来:
# 项目下的urls.py urlpatterns = [ ... # 包含应用下的urls.py文件 url(正则表达式, include('应用名.urls')) ]
在应用下的urls.py中,进行url请求的配置:
# 应用下的urls.py urlpatterns = [ # 每一个url配置项都需要调用url函数,指定两个参数 # 参数1: 匹配url的正则表达式 # 参数2: 匹配成功后执行的视图函数 url(正则表达式, 视图函数名), ]
案例:
通过http://127.0.0.1:8080/app01/index地址,要调用视图函数index访问首页。则可配置如下(域名和端口号不需要配置,只需要配置 app01/index 部分):
在app01应用中创建urls.py文件,在该文件中配置url和视图函数的对应关系:
# app01.py urlpatterns = [ ... # 进入首页 url(r'^index$', views.index), ]
在项目下urls.py中,把应用下的urls.py包含进来:
# Project01/urls.py urlpatterns = [ # 包含应用app01下的urls.py url(r'^app01/', include('app01.urls')), ]
url匹配流程
输入如下地址,访问首页:
http://127.0.0.1:8000/app01/index?aa=1&bb=xx
匹配流程:
url配置规则 (针对应用下的url配置)
正则表达式 应使用 ^ 和 $ 严格匹配请求url的开头和结尾,以便匹配唯一的字符串
url匹配小结:
- 域名、端口、参数不参与匹配
- 先到项目下的urls.py进行匹配,再到应用的urls.py匹配
- 自上而下的匹配
- 匹配成功的url部分会去掉,剩下的部分继续作匹配
- 匹配不成功提示404错误
视图函数
每一个请求的url地址,都对应着一个函数,叫视图函数,由视图函数处理请求后,再返回页面内容给浏览器显示。
在 应用/views.py 下,定义视图函数,示例:
from django.http import HttpResponse # 必须有一个参数request def index(request): """进入首页的视图函数""" # 处理完请求,返回字符串内容给浏览器显示 return HttpResponse("Hello Python")
捕获URL中的值
问题:对于如下的url地址,如何捕获url上的两个值(代表新闻类别和页码),并传给视图函数处理?
输入如下地址:
# /show_news/新闻类别/页码 http://127.0.0.1:8000/show_news/1/2
解决: 把url中的需要获取的值部分,设置为正则表达式的一个组。 django在进行url匹配时,就会自动把匹配成功的内容,作为参数传递给视图函数。
位置参数: url中的正则表达式组,和视图函数中的参数一一对应,函数中的参数名可以随意指定。
示例:
# 位置参数:新闻查看/新闻类别/第几页 url(r'^show_news/(\d+)/(\d+)$', views.show_news), # 视图函数:views.py def show_news(request, a, b): """显示新闻界面""" return HttpResponse("新闻界面:%s %s" % (a, b))
关键字参数: 在位置参数的基础上,对正则表达式分组进行命名:
?P<组名>
视图函数中参数名,必须和正则表达式分组名一致。
示例:
# 关键字参数:新闻查看/新闻类别/第几页 url(r'^show_news2/(?P<category>\d+)/(?P<page_no>\d+)$', views.show_news2), # 视图函数:views.py def show_news2(request, category, page_no): """显示新闻界面2""" return HttpResponse("新闻界面:%s %s" % (category, page_no))
错误视图
Django内置了处理HTTP错误的视图(在django.views.defaults包下),主要错误及视图包括:
- 404错误:page_not_found 视图 (找不到界面)
- 500错误:server_error 视图 (服务器内部错误)
- 403错误:permission_denied 视图 (权限拒绝)
一、404错误及视图
url匹配失败后,django会调用内置的 page_not_found 视图函数,该视图函数会调用 404.html的模板进行显示。
开发阶段可以开启调试模式,但产品上线后,要关闭调试模式。关闭调试模式后,会显示一个标准的错误页面
# 关闭调试模式(开发模式) DEBUG = False # 表示允许哪些域名可访问当前网站 ALLOWED_HOSTS = ['*']
404错误界面可以自定义: 在项目templates目录面创建404.html,django找不到界面时,就会使用该界面了
二、500错误及视图
若是在执行视图函数时出现运行时错误,Django会默认会调用 django.views.defaults.server_error 视图,加载并显示 500.html 模板:
server error (500)
类似的,可以在项目的templates目录下,创建500.html来自定义该界面。
三、Django出错日志查看:
查看 Exception Type 以及 Exception Value
查看 Traceback中的出错行
希望本文所述对大家基于Django框架的Python程序设计有所帮助。