目录标题
一:django请求生命周期流程图
二:路由匹配
1.原理
- 一旦网址后缀匹配上,就会自动执行后面的函数,并结束整个路由匹配
path('网址后缀',函数名)
path('index/', views.index)
2.关于路由结尾的斜杠
- 默认情况下不写斜杠,django会自动重定向到有斜杠的路径
- 如何取消django自动匹配斜杠? 在配置文件中加上:APPEND_SLASH=False
3.path转换器
- 1.什么时候用转换器?当网址后缀不固定的时候 可以使用转换器来匹配
- 2.如何写path转换器
path('login/<int:year>/<str:desc>/', views.login)
- 3.视图函数
- 转换器匹配到的内容会以关键字参数的形式传给视图函数
def login(request, year, desc):
- 4.转换器分类
# 常用
'int': IntConverter(),
'str': StringConverter(),
# 不常用
'path': PathConverter(),
'slug': SlugConverter(),
'uuid': UUIDConverter(),
4.re_path正则匹配
1.django2.x及以上的版本中默认的路由是path,所以re_path需要自己手动导入
from django.urls import re_path
2.如何书写re_path路由
re_path(正则表达式,函数名)
re_path('^test/$', views.test)
3.匹配原理:一旦网址后缀的正则能够匹配到浏览器端输入的内容,就会自动执行后面的函数,并结束整个路由匹配
5.无名分组
1.书写
re_path('^home/(\d+)/(.*?)/', views.home)
2.视图函数:正则表达式匹配到的内容会以位置参数的形式传给视图函数
def home(request, a, b)
6.有名分组
1.书写
re_path('^test1/(?P<year>\d+)/(?P<others>.*?)/')
2.视图函数:正则表达式匹配到的内容会以关键字参数的形式传给视图函数
def test1(request, a, b)
7.django不同版本中路由匹配的区别
1.django1.x版本中,只支持正则匹配,只有url( )方法
2.django2,3,4 版本中,默认的是path方法,re_path( )方法和django1.x版本中的url( )方法一样
三:反向解析
反向解析的操作三个方法都一样path() re_path() url()
1.引入反向解析
由于页面上提前写死了很多路由,一旦路由发生变化,会导致所有的页面相关链接失效,为了防止该问题的出现,需要反向解析
2.反向解析定义:
返回一个结果,该结果可以访问到对应的路由
3.路由对应关系起别名
path(<