Django视图

一、url路由

自上而下的,如果匹配的路由中是包含int转换器,则不能匹配其他的不是int的相关字符,譬如文字等;

自定义路由转换器:

1、创建一个converter.py的文件;

2、再写一个类:

class FourDigitYearConverter:

regex = '[0-9]{4}' # 类属性,一个字符串形式的正则表达式属性

def to_python(self, value): # 一个用来将字符串转换成你想要的那个数据类型,并传给视图;如果转换失败,它必须弹出ValueError异常。

return int(value)

def to_url(self, value): # 将Python数据类型转换成一段url的方法,与上面方法相反;如果转换失败,它也必须弹出ValueError异常。

return '%04d' % value

3、在该APP的url中注册它:

register_converter(converters.FourDigitYearConverter, 'yyyy')

使用样式:path('articles/yyyy:year/', views.year_archive)

在路由中使用正则表达式:语法是 (?Ppattern) ,其中 name 是组名,pattern 是要匹配的模式。

例如:re_path(r'^articles/(?P[0-9]{4})/(?P[0-9]{2})/(?P[\w-]+)/$', views.article_detail)

二、路由转发

路由中的命名最好不要和路径的url一样,不然有可能导致错误。

可以在include后面加上一个字典参数,但是该参数必须是各个子路由都会使用的,不然可能会出错。

三、反向解析和命名空间

1、反向解析url

def redirect_to_year(request):

...

year = 2020

...

return HttpResponseRedirect(reverse('news-year-archive', args=(year,)))

2、命名空间app_name和namespace:

在模板中使用的时候,用冒号隔开;

namespace定义在include中;整个项目的所有app中的所有namespace不能重名,也就是全局唯一;使用namespace功能的前提是设置app_name,如果不设置,会弹出异常;要在视图中获取namespace属性值,通过request.resolver_match.namespace。

四、函数视图及快捷方式

1、返回错误HttpResponseNotFound( );

Http404异常,返回Http404异常的时候需要用raise不能用return;

自定义各种错误页面:

#在子路由增加的条目

handler400 = views.bad_request

handler403 = views.permission_denied

handler404 = views.page_not_found

handler500 = views.error

然后在views中增加:

@requires_csrf_token

def bad_request(request, exception):

return render(request, '400.html')

2、内置的快捷方法

render(request,template_name,, context=None, content_type=None, status=None, using=None)

必需参数:

● request:视图函数处理的当前请求,封装了请求头的所有数据,其实就是视图参数request。

● template_name:要使用的模板的完整名称或者模板名称的列表。如果是一个列表,将使用其中能够查找到的第一个模板。

可选参数:

● context:添加到模板上下文的一个数据字典。默认是一个空字典。可以将认可需要提供给模板的数据以字典的格式添加进去。这里有个小技巧,使用Python内置的locals()方法,可以方便地将函数作用域内的所有变量一次性添加进去。

● content_type:用于生成的文档的MIME类型。 默认为DEFAULT_CONTENT_TYPE设置的值,也就是'text/html'。

● status:响应的状态代码。 默认为200。

● using:用于加载模板使用的模板引擎的NAME。

def my_view(request):

View code here...

return render(request, 'myapp/index.html', { 'foo': 'bar', }, content_type='application/xhtml+xml')

等同于:

def my_view(request):

View code here...

t = loader.get_template('myapp/index.html')

c = {'foo': 'bar'}

return HttpResponse(t.render(c, request), content_type='application/xhtml+xml')

重定向------redirect()

redirect(to, args, permanent=False, *kwargs)

根据传递进来的url参数,返回HttpResponseRedirect。

参数to可以是:

● 一个模型实例:将调用模型的get_absolute_url()函数,反向解析出目的url;

● URL的name名称:可能带有参数:reverse()将用于反向解析url;

● 一个绝对的或相对的URL:将原封不动的作为重定向的目标位置。

默认情况下是临时重定向,如果设置permanent=True将永久重定向。

相关推荐
多想和从前一样5 小时前
Django 创建表时 “__str__ ”方法的使用
后端·python·django
IT古董7 小时前
【开源向量数据库】Milvus简介
数据库·开源·milvus
web150850966417 小时前
SQL 建表语句详解
java·数据库·sql
宇智波云7 小时前
mysql增加字段操作以及关键字报错
java·数据库·mysql
怠惰_u7 小时前
使用Redis实现分布式锁,基于原本单体系统进行业务改造
数据库·redis·分布式
lozhyf8 小时前
后端开发:高效数据库查询优化实战指南
数据库·oracle
云泽野8 小时前
50道题快速复习MySQL之准备篇
数据库·mysql·oracle
林林总肿8 小时前
Mybatis后端数据库查询多对多查询解决方案
数据库·spring boot·mybatis
jay丿8 小时前
Redis简介
数据库·redis·缓存
格雷亚赛克斯9 小时前
Qt笔记31-69
数据库·笔记·qt