URLconf配置
基本格式
在urls.py文件中配置
from django.conf.urls import urlurlpatterns = [ url(正则表达式, views视图函数,参数,别名),]
这里需要注意的是:Django 2.0版本中的路由系统已经替换成下面的写法(官方文档)
参数说明
-
正则表达式:一个正则表达式字符串,用来匹配相关的路径;
-
views视图函数:一个可调用对象,通常为一个视图函数或一个指定视图函数路径的字符串。和视图函数相同的字符串,用来映射;
-
参数:可选的要传递给视图函数的默认参数(字典形式)
-
别名:一个可选的name参数。
正则表达式详解
基本配置
注意事项
-
urlpatterns 中的元素按照书写顺序从上往下逐一遍历匹配正则表达式,一旦匹配成功则不再继续;
-
若要从URL中捕获一个值,只需要在它周围放置一对圆括号(分组匹配);
-
不需要添加一个前导的反斜杠,因为每个URL都有。例如,应该是^articles而不是^/articles;
-
每个正则表达式前面的 'r' 是可选的,但是建议加上。
分组命名匹配
URLconf匹配的位置
捕获的参数永远都是字符串
每个在URLconf中捕获的参数都作为一个普通的Python字符串传递给视图,无论正则表达式使用的是什么匹配方式。例如,下面这行URLconf 中:
在上面的例子中,两个URL模式指向相同的view - views.page - 但是第一个模式并没有从URL中捕获任何东西。
如果第一个模式匹配上了,page()函数将使用其默认参数num=“1”,如果第二个模式匹配,page()将使用正则表达式捕获到的num值。
include其他的URLconfs
传递额外的参数给视图函数
URLconfs 具有一个钩子,让你传递一个Python 字典作为额外的参数传递给视图函数。
django.conf.urls.url()
函数可以接收一个可选的第三个参数,它是一个字典,表示想要传递给视图函数的额外关键字参数。
例如:
在这个例子中,对于/blog/2005/请求,Django 将调用views.year_archive(request, year='2005', foo='bar')。
这个技术在Syndication 框架中使用,来传递元数据和选项给视图。
命名URL和URL反向解析
url(r'^home', views.home, name='home'), # 给我的url匹配模式起名为 homeurl(r'^index/(d*)', views.index, name='index'), # 给我的url匹配模式起名为index
根据这里的设计,某一年nnnn对应的归档的URL是
/articles/nnnn/
。
你可以在模板的代码中使用下面的方法获得它们:
在Python 代码中,这样使用: