欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Django2.0中URL的路由机制

程序员文章站 2023-08-19 17:35:10
路由是关联url及其处理函数关系的过程。Django的url路由配置在settings.py文件中ROOT_URLCONF变量指定全局路由文件名称。 Django的路由都写在urls.py文件中的urlpatterns列表中,由path()或re_path()作为元素组成。 Django的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.对应处理函数)