URL配置(URLconf)就像Django 所支撑网站的目录。它的本质是URL模式以及要为该URL模式调用的视图函数之间的映射表;你就是以这种方式告诉Django,对于这个URL调用这段代码,对于那个URL调用那段代码。
在Django2.0以下的版本中,其格式为
urlpatterns = [
url(正则表达式, views视图函数,参数,别名),
]
参数说明:
- 一个正则表达式字符串
- 一个可调用对象,通常为一个视图函数或一个指定视图函数路径的字符串
- 可选的要传递给视图函数的默认参数(字典形式)
- 一个可选的name参数
在Django2.0以上的版本中需要from django.urls import re_path才能进行正则表达
from django.urls import path,re_path
其格式为
urlpatterns = [
path('表达式',view视图函数,参数,别名),
re_path('正则表达式',view视图函数,参数,别名)
]
urlpatterns = [
re_path('article/[0-9]{4}',views.article_year),
#这种形式不会把参数传给视图函数
re_path('article/([0-9]{4})',views.article_year),
#当正则表达式加上括号时,会将匹配到的字符串传给视图函数,其形参可以任意
re_path('article/(?P<year>[0-9]{4})',views.article_year),
#(?P<name>)为匹配到的字符串命名,然后传给视图函数,且视图函数的形参必须是相应的name
]
起别名是为了如果需要更改正则表达式,那么所以的相关引用都需要更改,但是如果用别名作为引用,只要别名不便,其他地方也无需变动。
其中正则表达式与之前一样,但是path还有用法,如
urlpatterns = [
re_path('article/(?P<year>[0-9]{4}$)',views.article_year),
path('article/<int:year>/<int:month>',views.article_month),
path('article/<int:year>/<int:month>/<slug>',views.article_detail),
path('register',views.register,name='reg')
]
基本规则:
- 使用尖括号(<>)从url中捕获值。
- 会将捕获到的值传给视图函数,形参必须与命名一样。
- 捕获值中可以包含一个转化器类型(converter type),比如使用 <int:name> 捕获一个整数变量。若果没有转化器,将匹配任何字符串,当然也包括了 / 字符。
- 无需添加前导斜杠。
Django默认支持以下5个转化器:
- str,匹配除了路径分隔符(/)之外的非空字符串,这是默认的形式
- int,匹配正整数,包含0。
- slug,匹配字母、数字以及横杠、下划线组成的字符串。
- uuid,匹配格式化的uuid,如 075194d3-6885-417e-a8a8-6c931e272f00。
- path,匹配任何非空字符串,包含了路径分隔符
路由分发
实际上每个应用都应该有一个URLs文件来进行url配置,而不是都放在主目录的URLs中。
所以我们应该为每个应用创建相应的urls文件,导入在主目录的urls文件中include
from django.urls import path,re_path,include
以blog应用为例
urlpatterns = [
path('admin/', admin.site.urls),
path('show_time/',views.show_time),
re_path('^blog/',include('blog.urls')),
]
注意最后一个表示所有blog相关的url配置都在自己的urls配置文件中查找。