自学python如何成为大佬(目录):https://blog.csdn.net/weixin_67859959/article/details/139049996?spm=1001.2014.3001.5501
Django的URL路由流程:
l Django查找全局urlpatterns变量(urls.py)。
l 按照先后顺序,对URL逐一匹配urlpatterns每个元素。
l 找到第一个匹配时停止查找,根据匹配结果执行对应的处理函数。
l 如果没有找到匹配或出现异常,Django进行错误处理。
Django支持三种表达格式,分别如下:
l 精确字符串格式,如“articles/2017/”。
一个精确URL匹配一个操作函数;最简单的形式,适合对静态URL的响应;URL字符串不以“/”开头,但要以“/”结尾。
l Django的转换格式:<类型:变量名>,如“articles/<int:year>/”。
该格式是一个URL模板,在匹配URL时获得一批变量作为参数;该格式也是一种常用形式,用于通过URL获取和传递参数。
表6提供了一些格式转换类型及其说明。
表6 格式转换类型及说明
格式转换类型 | 说 明 |
str | 匹配除分隔符(/)外的非空字符,默认类型<year>等价于<str:year> |
int | 匹配0和正整数 |
slug | 匹配字母、数字、横杠、下划线组成的字符串,str的子集 |
uuid | 匹配格式化的UUID,如075194d3-6885-417e-a8a8-6c931e272f00 |
path | 匹配任何非空字符串,包括路径分隔符,是全集 |
l 正则表达式格式,如“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。
注意:当网站功能较多时,可以在该功能文件夹里建一个urls.py文件,将该功能模块下的URL全部写在该文件里,但是要在全局的urls.py中使用include方法实现URL映射分发。
编写URL的三种情况如下:
l 普通URL:re_path('^index/',view.index),re_path('^home/',view.Home.as_view())
l 顺序传参:re_path(r'^detail-(\d+)-(\d+).html/',views.detail)
l 关键字传参:re_path(r'^detail-(?P<nid>\d+)-(?P<uid>\d+).html/',views.detail)
推荐使用关键字传参的路由方法,找到项目根目录的配置文件夹demo下面的urls.py,打开该文件,并添加如下代码:
from django.contrib import admin # 引入默认后台的模块,其中包括管理界面的urls路由规则
from django.urls import path, include # 引入urls模块中path方法
urlpatterns = [
path('admin/', admin.site.urls),
path('app1/',include('app1.urls'))
]
然后在app1下面创建一个urls.py文件,并在其中编写属于这个模块的url规则:
from app1 import views as app1_views
urlpatterns = [
# 精确匹配视图
path('articles/2003/', app1_views.special_case_2003),
# 匹配一个整数
path('articles/<int:year>/', app1_views.year_archive),
# 匹配两个位置的整数
path('articles/<int:year>/<int:month>/', app1_views.month_archive),
# 匹配两个位置的整数和一个slug类型的字符串
path('articles/<int:year>/<int:month>/<slug:slug>/', app1_views.article_detail),
]
如果想使用正则表达式匹配,则使用下面代码:
from django.urls import re_path
from app1 import views as views
urlpatterns = [
# 精确匹配
path('articles/2003/', views.special_case_2003),
# 按照正则表达式匹配4位数字年份
re_path(r'^articles/(?P<year>[0-9]{4})/$', views.year_archive),
# 按照正则表达式匹配4位数字年份和2位数字月份
re_path(r'^articles/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})/$', views.month_archive),
# 按照正则表达式匹配4位数字年份和2位数字月份和一个至少1位的slug类型的字符串
re_path(r'^articles/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})/(?P<slug>[\w-]+)/$', views.article_detail),
]
接下来即可通过“/app1/articles/2003/12/11/my_day”访问app1_views.article_detail这个视图方法了,效果如图25所示。
图25 访问视图方法