Django4 中文入门教程 Django4.0 URL调度器-注册自定义的路径转换器

2024-02-25 开发教程 Django4 中文入门教程 匿名 6

对于更复杂的匹配需求,你能定义你自己的路径转换器。

转换器是一个类,包含如下内容:

  • 字符串形式的 ​regex ​类属性。
  • 一个​to_python(self, value)​ 方法,用来处理匹配的字符串转换为传递到函数的类型。如果没有转换为给定的值,它应该会引发 ​ValueError ​。​ValueError ​说明没有匹配成功,因此除非另一个 URL 模式匹配成功,否则会向用户发送404响应。
  • 一个 ​to_url(self, value)​ 方法,它将处理 Python 类型转换为字符串以用于 URL 中。如果不能转换给定的值,它应该引发 ​ValueError​。​ValueError ​被解释为无匹配项,因此 ​reverse()​ 将引发 ​NoReverseMatch​,除非有其他 URL 模式匹配。

例如:

class FourDigitYearConverter:
regex = '[0-9]{4}'
def to_python(self, value):
return int(value)
def to_url(self, value):
return '%04d' % value

在 ​URLconf ​中使用 ​register_converter()​ 来注册自定义的转换器类:

from django.urls import path, register_converter
from . import converters, views
register_converter(converters.FourDigitYearConverter, 'yyyy')
urlpatterns = [
path('articles/2003/', views.special_case_2003),
path('articles/<yyyy:year>/', views.year_archive),
...
]