您的位置:首页 > 健康 > 美食 > 路由(urls)

路由(urls)

2024/12/23 16:42:28 来源:https://blog.csdn.net/weixin_67859959/article/details/139938850  浏览:    关键词:路由(urls)

自学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   访问视图方法

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com