自定义URL(PATH)转换器笔记:
需求:
实现一个获取文章列表的demo,用户可以根据/articles/文章分类/
的方式来获取文章。其中文章分类采用的是分类1+分类2+分类3...
的方式拼接的,并且如果只有一个分类,那就不需要加号。示例如下:
# 1. 第一种:获取python分类下的文章
/articles/python/
# 2. 第二种:获取python和django分类下的文章
/articles/python+django/
# 3. 第三种:获取python和django和flask分类下的文章
/articles/python+django+flask/
以此类推...
在“文章分类”参数传到视图函数之前要把这些分类分开来存储到列表中。
比如参数是python+django
,那么传到视图函数的时候就要变成['python','django']
。
以后在使用reverse反转的时候,限制传递“文章分类”的参数应该是一个列表,并且要将这个列表变成python+django
的形式。
自定义URL转换器:
之前已经学到过一些django内置的url转换器,包括有int、uuid等。有时候这些内置的url转换器并不能满足我们的需求,因此django给我们提供了一个接口可以让我们自己定义自己的url转换器。
自定义url转换器按照以下五个步骤来走就可以了:
- 定义一个类,直接继承自object就可以了。
- 在类中定义一个属性regex,这个属性是用来限制url转换器规则的正则表达式。
- 实现to_python(self,value)方法,这个方法是将url中的值转换一下,然后传给视图函数的。
- 实现to_url(self,value)方法,这个方法是在做url反转的时候,将传进来的参数转换后拼接成一个正确的url。 5. 将定义好的转换器,使用
django.urls.converters.register_converter
方法注册到django中。
示例代码如下:
from django.urls import register_converter
class CategoryConverter(object):
regex = r'\w+|(\w+\+\w+)+'
def to_python(self,value):
# python+django+flask
# ['python','django','flask']
result = value.split("+")
return result
def to_url(self,value):
# value:['python','django','flask']
# python+django+flask
if isinstance(value,list):
result = "+".join(value)
return result
else:
raise RuntimeError("转换url的时候,分类参数必须为列表!")
register_converter(CategoryConverter,'cate')