path(route, view, kwargs=None, name=None)
示例:
from django.urls import include, path
urlpatterns = [
path('index/', views.index, name='main-view'),
path('bio/<username>/', views.bio, name='bio'),
path('articles/<slug:title>/', views.article, name='article-detail'),
path('articles/<slug:title>/<int:section>/', views.section, name='article-section'),
path('blog/', include('blog.urls')),
]
1、route
参数应该是一个字符串或 gettext_lazy() (参见 翻译URL模式),它包含一个 URL 模式。这个字符串可以包含角括号(就像上面的 <username>
)来捕获 URL 的一部分,并将其作为关键字参数发送给视图。角括号可以包含一个转换器规格(像 <int:section>
的 int
部分),它限制了匹配的字符,也可以改变传递给视图的变量的类型。例如,<int:section>
匹配一串十进制数字,并将值转换为 int
。更多细节请参见 Django 如何处理一个请求。
2、view
参数是一个视图函数或 as_view() 的结果,用于基于类的视图。它也可以是一个 django.urls.include()。
3、kwargs
参数允许你向视图函数或方法传递附加参数。参见 传递额外选项给视图函数 的例子。
re_path(route, view, kwargs=None, name=None)
from django.urls import include, re_path
urlpatterns = [
re_path(r'^index/$', views.index, name='index'),
re_path(r'^bio/(?P<username>\w+)/$', views.bio, name='bio'),
re_path(r'^blog/', include('blog.urls')),
]
1、route
参数应该是一个字符串或 gettext_lazy() (参见 翻译URL模式),它包含一个与 Python 的 re 模块兼容的正则表达式。字符串通常使用原始字符串语法(r''
),因此它们可以包含像 /d
这样的序列,而不需要用另一个反斜杠来转义。当进行匹配时,从正则表达式中捕获的组会被传递到视图中 —— 如果组是命名的,则作为命名的参数,否则作为位置参数。值以字符串的形式传递,不进行任何类型转换
2、参数二、参数三、参数四跟path()一样