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.对应处理函数)

posted @ 2018-07-19 19:51  裙下的小香蕉  阅读(332)  评论(0编辑  收藏  举报