一、URL的基本配置如下:
from django.conf.urls import url
from . import views
urlpatterns = [
url(r’^blog/[0-9]+/$’, views.page), # 捕捉到的参数不命名
url(r’^blog/page(?P[0-9]+)/$’, views.page), # 正则表达式匹配到的参数命名为num
]
views.py中的方法如下:
def page(request, num):
print “page_num”, num
*正则表达式最好以
结尾,这样能根据URL的内容进行精准的匹配,如果不加
,会出现路由错误的情况:
例如:
第一种情况:
urlpatterns = [
url(r’^query/’, views.query),
url(r’^query/supply_hotel/’, views.supply_hotel),
]
访问query/supply_hotel/会路由到query/,因为query/在前,此种情况,如果把query/supply_hotel/’写在第一列就不会出现问题。
第二种情况:
urlpatterns = [
url(r’^query/
′,views.query),url(r′query/supplyhotel/
’, views.supply_hotel),
]
访问query/supply_hotel/会正确路由
二、django处理URL参数命名冲突的方式
It’s possible to have a URL pattern which captures named keyword arguments, and also passes arguments with the same names in its dictionary of extra arguments. When this happens, the arguments in the dictionary will be used instead of the arguments captured in the URL.
从URL中通过正则获得的命名参数如果与额外传入的字典参数中有冲突,则使用字典中的参数
例如:
urlpatterns = [
url(r’^blog/page(?P[0-9]+)/$’, views.page,{“num”:12}),
]
则访问blog/page/16/时,传入的参数num会为12
三、是否捕捉URL参数
官方文档原文:
As a rule of thumb, only capture the values the view needs to work with and use non-capturing arguments when the regular expression needs an argument but the view ignores it.
理解:
当view中需要用到URL中的参数时才捕捉参数
当路由需要,但view不需要时,不需要捕捉URL中的参数
四、嵌套URL参数
from django.conf.urls import url
urlpatterns = [
url(r’blog/(page-(\d+)/)?’, blog_articles), # bad
url(r’comments/(?:page-(?P\d+)/)?’, comments), # good
]
假设链接为blog/page-2/
第一条路由,将传递两个位置参数,分别为page-2和2
假设链接为comments/page-2/
第二条路由,传递的变量名称为page_number,值为2,注意,不会捕捉(?:……)的内容