Django2.0中URL的路由机制
路由是关联url及其处理函数关系的过程。django的url路由配置在settings.py文件中root_urlconf变量指定全局路由文件名称。
django的路由都写在urls.py文件中的urlpatterns列表中,由path()或re_path()作为元素组成。
django的url路由流程:
1 django查找全局urlpatterns变量(urls.py)
2 按照先后顺序,对url逐一匹配urlpatterns每个元素
3 找到第一个匹配时停止查找,根据匹配结果执行对应的处理函数。
4 如果没有找到匹配或出现异常,django进行错误处理
注意:
django的路由不考虑http请求方式,仅根据url进行路由,即,只要url相同,无论post、get等哪种请求方式都指向同一个操作函数。
urlpatterns中的path()处理字符串路由,re_path处理正则表达式路由。
其格式:
urlpatterns=[
path(route,views.函数名,向处理函数提供的额外参数,以字典形式表示,该url模式的别名),
re_path(正则表达式,view.对应的处理函数)
]
其中正则表达式可以看做字符串的模式。
django支持三种表达route:
1、 精确字符串格式:articles/2017/
一个精确url匹配一个操作函数;最简单的形式,适合对静态url的响应;url字符串不以“/”开头,但要以“/”结尾
2、 django的转换格式:<类型:变量名>,articles/<int:year>/
是一个url模版,匹配url同时在其中获得一批变量作为参数;是一种常用形式,目的是通过url进行参数获取和传递
转换格式类型 |
说明 |
str |
匹配除分隔符(/)外的非空字符,默认类型<year>等价于<str:year> |
int |
匹配0和正整数 |
slug |
匹配字母、数字、横杠、下划线组成的字符串,str的子集 |
uuid |
匹配格式化的uuid,如075194d3-6885-417e-a8a8-6c931e272f00 |
path |
匹配任何非空字符串,包括路径分隔符,是全集 |
3、 正则表达式格式:articles/(?p<year>[0-9]{4})/
借助正则表达式丰富语法表达一类url(而不是一个);可以通过<>提取变量作为处理函数的参数,高级用法;使用该方法时,前面不能使用path()函数,必须使用re_path()函数;表达的全部是str格式,不能是其他类型。
两种形式:不提取参数,比如re_path(articles/([0-9]{4}/,表示四位数字,每一个数字都是0到9的任意数字;提取参数,命名形式(?p<name>pattern),比如re_path(articles/(?p<year>[0-9]{4})/,将正则表达式提取的四位数字,每一个数字都是0到9的任意数字命名为year,
当视图函数路径较多时,可以使用include()用法进行去重:
urlpatterns=[ path(‘<page_slug>-<page_id>/history/’,views.history), path(‘<page_slug>-<page_id>/edit/’,views.edit), ]
等价于:
urlpatterns = [ path(‘<page_slug>-<page_id>/’,include([ path(‘history/’,views.history), path(‘edit/’,views.edit), ]
当网站功能较多时可以在该功能文件夹里建一个urls.py文件,将该功能模块下的url全部写在该文件里。但是要在全局的urls.py中使用include方法实现url映射分发。
例如:网站有论坛模块,则在论坛模块下建个urls.py文件,将与论坛相关的页面的url全部写在这个文件里,然后在全局的urls.py文件里这样写:
from django.urls import path,include urlpatterns = [ path('admin/', admin.site.urls), path('ant_test/',include('ant_test.urls')) ]
在论坛模块下的urls.py文件这样写:
from django.urls import path urlpatterns = [ path('news/',views.news), ]
在views.py中写对应的news函数即可。
django2.0版本中path(route,views.对应处理函数)等价于低版本的url(r'^route/$’,views.对应处理函数)
上一篇: 老婆在教育儿子