Django 自学笔记兼学习教程第2章第2节——URL详细匹配规则

点击查看教程总目录

本章第一节中我们简单介绍了URL与View关系

简单概括来说,网页请求的url会通过urls.py里面的urlpatterns列表中的urlpattern来匹配对应的view方法,然后view方法会返回一个HttpResponse

过程示意如下:

url - > urlpattern - > view

本节就来详细说下这个匹配关系

本文参考文献:module-django.urls.conf

1- urlpattern

urlpattern可以调用两种函数获得:django.urls.path()django.urls.re_path()

后者是用于正则匹配url的(新手一般用不到)

这两种函数的参数和含义是一样的

path(route, view, kwargs=None, name=None)
re_path(route, view, kwargs=None, name=None)
  • route : 要匹配的url
  • view : 匹配后要调用的view函数名
  • kwargs: 向view函数传递额外的参数(route也可以传递参数给view, 所以对于新手来说,kwargs这个比较少用到)
  • name: urlpattern的名字,主要用于后面在模板中指定urlpattern。(因为url中间可能会修改,模板中写死了的话,改起来麻烦)

2 - 传参

本章第一节中我们举了个最简单的hello例子。 这里我们进行一个简单的拓展思考,如果这个hello后面要跟上访问的人的名字呢

比如浏览器访问http://127.0.0.1:8000/hello/tony, 希望返回结果hello, tony

访问http://127.0.0.1:8000/hello/Bob, 希望返回hello, Bob

这个时候如果像第一节里面那样一个一个写,就麻烦了,一个名字就要写一个view方法,也不现实。

所以我们需要能够把route的一些字段作为参数传递给view函数

比如要将http://127.0.0.1:8000/hello/Bob中的Bob作为参数的话,那么可以这么写

path('hello/<slug:name>', views.hello)

同时views.py中的hello方法也要添加一个参数勇于去接受这个传入的变量

def hello(request, name):
return HttpResponse("Hello, %s" % name)

这里细下这句'hello/<slug:name>'

  1. 若要从URL捕获字符串作为参数传递给view函数,需要使用尖括号,尖括号内写捕获后的变量名。

    比如'hello/<name>'就会将name对应位置的字符串捕获并以name作为变量名传入view函数。
  2. 捕获的值可以选择性地包括转换器类型,设置后会将捕获后的字符串转换为对应类型。例如,使用<int:value>来捕获整型参数, 其中:前为转换器类型,:后为捕获后的变量名。(如果不包含转换器,则匹配除/字符外的任何字符串)

详细官方文档:urls/#example

3 转换器(converters)类型

Django默认的转换器有:

  • str:转换器默认值,匹配除路径分隔符'/'外的任何非空字符串
  • int:匹配零或任何正整数,返回一个int
  • slug:匹配由ASCII字母或数字以及连字符和下划线组成的任何slug字符串。
  • uuid:匹配格式化的UUID,返回一个UUID实例。
  • path:匹配任何非空字符串,包括路径分隔符'/'。

前三个用的比较多,新手应该暂时用不到后两个。

同时对于更复杂的匹配需求,可以定义自己的路径转换器,

具体可查阅官方文档: registering-custom-path-converters

4 使用include收纳不同app的url

对于一个网站系统而言,可能会有很多功能模块app,每个功能模块app又有各自的urlpatterns

如果这些全部都放在项目文件夹project_name下的项目名文件夹project_name/project_name中的urls.py中的话,

会很混乱也不方便管理,所以最好的办法是,每个功能模块app对应的urlpatterns放在app文件夹下的,然后在project_name/project_name中的urls.py使用include方法进行导入。

以我在做的简易教务系统为例,其有两个app: usercourse

要导入 user中的url到主url中的话,

则主urls.py(详细路径为SSCMS/SSCMS/urls.py)代码如下

from django.urls import path, include

urlpatterns = [
path('user/', include("user.urls")),
# ... other urlpatterns
]

SSCMS/user/urls.py

from django.urls import path
from user import views urlpatterns = [
path('login/', views.home, name="login"),
path('login/<slug:kind>', views.login, name="login"),
path('register/<slug:kind>', views.register, name="register"), path('update/<slug:kind>', views.update, name="update"),
path('logout/', views.logout, name="logout"),
]

此事要访问user中的名为login的urlpattern的话,浏览器应该请求的网站为

http://127.0.0.1:8000/user/login/

使用include方法

实际上会将一组url“根植到”其他url之下。

比如上面的例子就将SSCMS/user/urls.py中的urlpatterns“根植”到SSCMS/SSCMS/urls.py中的user/下。

更多细节,可见include的官方文档:including-other-urlconfs

Django笔记&教程 2-2 URL详细匹配规则的更多相关文章

  1. Django笔记&教程 总目录

    本篇博客只有目录,正文内容在目录章节链接的博客里 除目录本身外,没有链接的章节,说明内容还没开始编辑 本项目笔记仍在不断创作中,还有些内容会根据自身所学不断更新完善 本项目主要为markdwon文档, ...

  2. Django笔记 —— 高级视图和URL配置

    最近在学习Django,打算玩玩网页后台方面的东西,因为一直很好奇但却没怎么接触过.Django对我来说是一个全新的内容,思路想来也是全新的,或许并不能写得很明白,所以大家就凑合着看吧- 本篇笔记(其 ...

  3. Caliburn.Micro学习笔记(一)----引导类和命名匹配规则

    Caliburn.Micro学习笔记目录 用了几天时间看了一下开源框架Caliburn.Micro 这是他源码的地址http://caliburnmicro.codeplex.com/ 文档也写的很详 ...

  4. djanjo中url路由匹配规则是啥意思

    一,django路由匹配规则的本质是通过正则表达式对用户的url进行匹配. 1,r 是正则表达式中防止转义的符号,例如在python/n代表换行,加上r就不换行了. 2,$ 正则表达式中表示以什么什么 ...

  5. Django笔记&教程 2-1 URL与View关系

    Django 自学笔记兼学习教程第2章第1节--URL与View关系 点击查看教程总目录 参考:how-django-processes-a-request 1- Django处理请求(request ...

  6. Django笔记&教程 3-3 模板常用语法

    Django 自学笔记兼学习教程第3章第3节--模板常用语法 点击查看教程总目录 本文主要参考:https://docs.djangoproject.com/en/2.2/ref/templates/ ...

  7. Django笔记&教程 1-1 一 新建项目

    Django 自学笔记兼学习教程第1章第1节--一 新建项目 点击查看教程总目录 1- 命令行新建Django项目 新建项目命令(project_name处为项目名) django-admin sta ...

  8. Django笔记&教程 5-2 进阶查询——Queryset

    Django 自学笔记兼学习教程第5章第2节--进阶查询--Queryset 点击查看教程总目录 Queryset相关内容其实蛮多的,本文只介绍一些常用的,详细的推荐查询官方文档:queryset-a ...

  9. Django笔记&教程 6-2 表单(Form)基础操作

    Django 自学笔记兼学习教程第6章第2节--表单(Form)基础操作 点击查看教程总目录 1 - 编写表单类 创建新的表单类的代码,一般写到一个专门的forms.py文件中(一般放在对应的app文 ...

随机推荐

  1. 1.pytest初尝试

    语法规范 pytest命令会默认执行以 -- test_**.py -- 或 -- **_test.py -- 命名文件的测试用例 pytest的测试用例必须以 -- test -- 开头 def t ...

  2. 踩坑系列《十》Python pip 安装问题一站式解决

    在使用Python编程语言时,难免要安装第三方库 安装一般都是在cmd命令行窗口安装 1.常规安装 ,在窗口输入 pip install 你要下载的库 这种方式一般网速比较慢,毕竟是从国外下载的 2. ...

  3. 洛谷4299首都(LCT维护动态重心+子树信息)

    这个题目很有意思 QWQ 根据题目描述,我们可以知道,首都就是所谓的树的重心,那么我们假设每颗树的重心都是\(root\)的话,对于每次询问,我们只需要\(findroot(x)\)就可以. 那么如何 ...

  4. Oil Deposits 新年特辑篇

    链接:E - Oil Deposits 题目: The GeoSurvComp geologic survey company is responsible for detecting undergr ...

  5. 3.4 Common Principles 通用原则

    3.4 Common Principles 通用原则 Before going into details, let's see some overall DDD principles; 在讨论细节之前 ...

  6. 【Takin使用日记】记一次TransmittableThreadLocal引起的业务异常

    对于常见的 WEB 容器,Takin 通过增强 org.apache.catalina.core.StandardHostValve#invoke 方法,拦截并解析方法入参的 Request 对象中的 ...

  7. Scrum Meeting 0522

    零.说明 日期:2021-5-22 任务:简要汇报两日内已完成任务,计划后两日完成任务 备注:由于在Beta冲刺阶段的最后一周中团队成员需要准备必修课程计算机网络的相关考试,所以为了保证Beta功能的 ...

  8. Seata分布式事务失败通知

    一.背景 在我们使用Seata作为分布式事务时,有些时候我们的分布式时候并不是每次都可以成功的,而对于这些失败的分布式事务就需要进行通知.这篇文章简单记录一下如何实现通知. 二.功能实现 此处模拟邮件 ...

  9. activiti会签 多实例例子

    在实际的业务中,可能存在存在这么一种情况,当流程运行到某一个环节时,可能需要同时多个人的参与,才可以完成此环节.此时就可以用到activiti的多实例来解决此问题. 一.将一个节点设置成多实例的方法: ...

  10. Noip模拟81 2021.10.20

    T1 语言 比较简单的题,然后就瞎写了,所以考场上就我一个写了线段树的,所以我的常数.... 所以就枚举动词的位置,找前面后面有没有出现$4$即可 1 #include<bits/stdc++. ...