Django之路由系统

Django的路由系统

URL配置(URLconf)就像Django所支撑网站的目录。它的本质是URL与要为该URL调用的视图函数之间的映射表。

我们就是以这种方式告诉Django,遇到哪个URL的时候,要对应执行哪个函数。

Django 1.11版本 URLConf官方文档

URLconf配置

基本格式:

from django.conf.urls import url

urlpatterns = [
     url(正则表达式, views视图,参数,别名),
]

示例:

from django.conf.urls import url
from . import views

urlpatterns = [
    url(r'^articles/2003/$', views.special_case_2003),
    url(r'^articles/([0-9]{4})/$', views.year_archive),
    url(r'^articles/([0-9]{4})/([0-9]{2})/$', views.month_archive),
    url(r'^articles/([0-9]{4})/([0-9]{2})/([0-9]+)/$', views.article_detail),
]

参数说明:

  • 正则表达式:一个正则表达式字符串
  • views视图:一个可调用对象,通常为一个视图函数
  • 参数:可选的要传递给视图函数的默认参数(字典形式)
  • 别名:一个可选的name参数

正则表达式详解

基本配置

复制代码
from django.conf.urls import url

from . import views

urlpatterns = [
    url(r'^articles/2003/$', views.special_case_2003),
    url(r'^articles/([0-9]{4})/$', views.year_archive),
    url(r'^articles/([0-9]{4})/([0-9]{2})/$', views.month_archive),
    url(r'^articles/([0-9]{4})/([0-9]{2})/([0-9]+)/$', views.article_detail),
]
复制代码

注意事项

  1. urlpatterns中的元素按照书写顺序从上往下逐一匹配正则表达式,一旦匹配成功则不再继续。
  2. 若要从URL中捕获一个值,只需要在它周围放置一对圆括号(分组匹配)。
  3. 不需要添加一个前导的反斜杠,因为每个URL 都有。例如,应该是^articles 而不是 ^/articles。
  4. 每个正则表达式前面的'r' 是可选的但是建议加上。

补充说明

# 是否开启URL访问地址后面不为/跳转至带有/的路径的配置项
APPEND_SLASH=True

Django settings.py配置文件中默认没有 APPEND_SLASH 这个参数,但 Django 默认这个参数为 APPEND_SLASH = True。 其作用就是自动在网址结尾加'/'。

其效果就是:

我们定义了urls.py:

from django.conf.urls import url
from app01 import views

urlpatterns = [
    url(r'^blog/$', views.blog),
]

访问 http://www.example.com/blog 时,默认将网址自动转换为 http://www.example/com/blog/ 。

如果在settings.py中设置了 APPEND_SLASH=False,此时我们再请求 http://www.example.com/blog 时就会提示找不到页面。

分组、命名分组

分组

 url(r'^(publisher|book)/$', views.showPage,name="show"),    #正则表达式中(),捕获括号中的参数,并且按照位置传参的方式传递给函数

命名分组

 url(r'^(?P<table>book|publisher)/delete/(?P<del_id>d+)/$', views.delete, name='del'),       #正则表达式中(?P<name>d+)捕获括号中的参数,并且按照关键字传参的方式传递给函数

   视图函数中,捕获到的参数永远是字符串类型。

include

root_urlconf  -->  根url,在settings文件中配置 ROOT_URLCONF = 'book_manager.urls'

urlpatterns = [
   url(r'^admin/', admin.site.urls),
   url(r'^app01/', include('app01.urls')),
   url(r'^app02/', include('app02.urls')),
]

app01 urlconf

urlpatterns = [
   url(r'^publisher/$', views.publisher),
   url(r'^publisher/add/$', views.add_publisher),
   url(r'^edit_publisher/(d+)/$', views.edit_publisher),
]

URL命名和反向解析

  给上一个URL的别名,根据这个别名获取到完整的URL地址的字符串

静态的url

命名:

  url(r'^publisher/$', views.publisher, name='publisher')      # 别名为 'publisher'

反向解析:

模板:    
  {% url 'publisher' %}  -->  '/app01/publisher/'
                        
py文件:   
from django.urls import reverse
  reverse('publisher') # 使用reverse函数解析到url路径 --> '/app01/publisher/'

分组

命名:

  url(r'^book/([0-9]{4})/(d{2})/$', views.book, name='book'),
  url(r'^edit_publisher/(d+)/$', views.edit_publisher,name='edit_publisher'),

反向解析:

模板:    
  {% url 'book' '2019' '05' %}  -->  空格分割,后面写位置参数  '/app02/book/2019/05/'    
                   
py文件:   reverse(
'edit_publisher',args=('2',)) --> args中写位置参数,元祖类型 '/app01/edit_publisher/2/'

命名分组

命名:

  url(r'^book/(?P<year>[0-9]{4})/(?P<month>d{2})/$', views.book, name='book'),

反向解析:

模板:    
  {% url 'book' '2019' '05' %}  -->   也可以用位置参数,安装顺序传参  '/app02/book/2019/05/'    
  {% url 'book' year='2019' month='05' %}  -->   使用关键字参数  '/app02/book/2019/05/'    

py文件:   reverse(
'book', args=('2019','06')) --> '/book/2019/06/'   reverse('book', kwargs={'year':'2017','month':'05'}) --> '/book/2017/05/'

namespace

即使不同的APP使用相同的URL名称,URL的命名空间模式也可以让你唯一反转命名的URL。

举个例子:

project中的urls.py

from django.conf.urls import url, include
 
urlpatterns = [
    url(r'^app01/', include('app01.urls', namespace='app01')),
    url(r'^app02/', include('app02.urls', namespace='app02')),
]

app01中的urls.py

from django.conf.urls import url
from app01 import views
 
app_name = 'app01'
urlpatterns = [
    url(r'^(?P<pk>d+)/$', views.detail, name='detail')
]

app02中的urls.py

from django.conf.urls import url
from app02 import views
 
app_name = 'app02'
urlpatterns = [
    url(r'^(?P<pk>d+)/$', views.detail, name='detail')
]

现在,我的两个app中 url名称重复了,我反转URL的时候就可以通过命名空间的名称得到我当前的URL。

语法:

'命名空间名称:URL名称'

模板中使用:

{% url 'app01:detail' pk=12 pp=99 %}

views中的函数中使用

v = reverse('app01:detail', kwargs={'pk':11})

 这样即使app中URL的命名相同,我也可以反转得到正确的URL了。

原文地址:https://www.cnblogs.com/root0/p/10868119.html