Django框架(四)—— 路由控制:有名/无名分组、反向解析、路由分发、名称空间、伪静态、APPEND_SLASH、不同版本的Django区别

你说的曾经没有我的故事 提交于 2021-01-08 22:58:57

路由控制

一、简单路由配置

url(r'^booklist$', views.booklist)
  • 第一个参数是正则表达式,第二个参数是视图函数
  • 每个正则表达式前面的'r' 是可选的但是建议加上。它告诉Python 这个字符串是“原始的” —— 字符串中任何字符都不应该转义
url(r'booklist', views.booklist)
url(r'booklistadd', views.booklistadd)

如果不加^ 和 $ ,由于路由匹配是从上往下匹配的,若是要匹配 booklistadd ,则很可能会匹配到booklist就会停止匹配

二、无名分组

url(r'^booklist/([0-9]{4})/([0-9]{2})/$', views.booklist)

def booklist(request, a, b) 或者 def booklist(request, *args)
  • 按位置传参
  • () 表示分组,分组后,会把分组出来的数据当做位置参数,传递到视图函数
  • 视图函数中必须要有位置参数接收分组出来的数据。由于分组出来的数据可能有很多,所以也可以用 *args 来用一个元组接收所有数据。

三、有名分组

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

def booklist(request, year, month)
  • 按关键字传参
  • 分组后,会把分组出来的数据按关键字传参,传递到视图函数
  • 视图函数需要定义形参来接收,并且视图函数中形参的名字要跟分组的名字一样,与顺序无关

四、反向解析

1、什么是反向解析

在Django中,经常需要获取某条URL,为生成的内容配置URL链接。

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

如在a标签中,<a href='/booklist/'>,倘若url发生了变化,就必须要去html中手动修改a的href,这样会浪费大量的工作时间。因此,Django提供一种方案,在url中提供一个name参数,相当于是给url取了一个名字。

url(r'^booklist$', views.booklist,name='book_url')

2、使用反向解析获取url

(1)三种url
# 1.无参
url(r'^booklist$', views.booklist,name='book_url')
# 2.有参,无名分组
url(r'^userlist/([0-9]{4})/([0-9]{2})/$',views.userlist,name='user_url') # 3.有参,有名分组 url(r'^manlist/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})/$',views.manlist,name='man_url')
(2)模板层
# 1.无参
<form action="{{% url 'book_url' %}}">
# 2.有参,无名分组, 2008 和 12 表示两个参数,即两个分组
{{% url 'user_url' 2008 12 %}} # 3.有参,有名分组 {{% url 'man_url' 2018 12 %}} 或者 {{% url 'man_url' year=2018 month=12 %}}
(3)视图层
from django.conf.urls import redirect,reverse 

# 1.无参
url=reverse('book_url')
return redirect(url) # 2.有参,无名分组, 2008 和 12 表示两个参数,即两个分组 url=reverse('user_url',args=(2018,12,)) # 3.有参,有名分组 url=reverse('man_url',args=(2018,12,)) 或者 url=reverse('man_url',kwargs={'year':2018,'mounth':12})

五、路由分发

1、在不同的app中创建子路由urls.py

2、在总路由中配置

from django.conf.urls import include 

url(r'^app01/',include('app01.urls'))
url(r'^blog/',include('blog.urls'))

3、在不同app的urls中配置路由

# 在app01中,urls.py
url(r'booklist$',views.booklist)
# 在blog中,urls.py
url(r'userlist$',views.userlist)

六、名称空间(一般不使用)

1、什么是名称空间

命名空间(英语:Namespace)是表示标识符的可见范围。一个标识符可在多个命名空间中定义,它在不同命名空间中的含义是互不相干的。

# 总路由
url(r'^app01/',include('app01.urls',namespace='app01'))
url(r'^blog/',include('blog.urls',namespace='blog'))
# 子路由
# app01中
url(r'^publish/$', views.publish,name='test')
# blog中 url(r'userlist$',views.userlist,name='test') 

2、使用名称空间

名称空间 : 路由别名

视图层:url = reverse('blog:test')
模板层:{% url 'app01:test'%}

七、伪静态

为了更好的被搜索引擎收录而通过一定的规则,把动态页面的地址转换成以htm或html结尾的地址,看起来是静态的,实际是依然是动态页面。

例如访问http://127.0.0.1:8000/book/4.html,它看上去是静态网站,但是其实其中的数据是通过后台获取实时更新的。

# 路由,用html结尾
url(r'^book/(?P<id>\d+.html)',views.book),

八、Django 2.x和Django 1.x 路由层区别

1、Django2.x中

  • re_path:跟1.0的url用法相同
  • path:传的路径,是准确路径
urlpatterns = [path('test/',view.test), ]

2、转换器

5个转换器

path('test/<path:year>', views.re_test)
# year 表示名字,path表示year是path类型的
str,匹配除了路径分隔符(/)之外的非空字符串,这是默认的形式
int,匹配正整数,包含0。
slug,匹配字母、数字以及横杠、下划线组成的字符串。
uuid,匹配格式化的uuid,如 075194d3-6885-417e-a8a8-6c931e272f00。 path,匹配任何非空字符串,包含了路径分隔符(/)(不能用?)

3、自定义转换器

# 1 定义一个类:
class MyCon:
    # 写一个正则表达式 regex = '[0-9]{4}' # 匹配出來的数据,会传到这里,retrun回去的,会被视图函数接收 def to_python(self, value): return int(value) # 反向解析用的 def to_url(self, value): return '%04d' % value # 2.注册转换器 from django.urls import register_converter register_converter(MyCon,'yyy') # 3.使用自定义转换器 path('test/<yyy:year>', views.re_test,name='test'),

九、APPEND_SLASH

# 是否开启URL访问地址后面不为/跳转至带有/的路径的配置项
APPEND_SLASH=True
  • Django settings.py配置文件中默认没有 APPEND_SLASH 这个参数,但 Django 默认这个参数为 APPEND_SLASH = True。 其作用就是自动在网址结尾加'/'

  • 默认APPEND_SLASH = True,即会自动在网址末尾加上 ‘/’

如访问 https://www.cnblogs.com 时,默认会加上 ‘/’,相当于方位了 https://www.cnblogs.com/

如果设置了APPEND_SLASH = False,访问 https://www.cnblogs.com 就不会加’/‘,就找不到页面

博客内容仅供参考,部分参考他人优秀博文,仅供学习使用
标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!