django3-路由系统进阶
1.django的url到底是什么
就是路径 ,看成django的目录 ,每个目录对应个视图函数 ,当然一个url仅能对应一个函数
2.url的格式
url(正则表达式,views函数名,参数,别名)
这里的正则表达式有个问题就是可能会匹配到多个路径 ,匹配的方式是从上到下匹配即停 ,所以正则一定要严谨防止截胡
斜线' / '末尾加上会好很多,开头不用加
#urls.py
from app01 import views #加载应用的地址函数模块
from app02 import views as app02views #这里一个问题就是不同应用的同名文件可以使用as来取别名
urlpatterns = [
url(r'^admin/$', admin.site.urls),
url(r'^admin/add/', admin.site.urls),
url(r'^admin/del/', admin.site.urls),
url(正则表达式,views函数,参数,别名),
]
3.路由分发
场景: 当app过多所有的url都写在项目目录下的urls.py肯定是不行 ,所以要在每个app下都创建一个urls.py分发到各个app下即可 ,使用的是include函数做路由分发
#/项目目录下/urls.py
from django.conf.urls import url,include
from django.contrib import admin
from app1 import views urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^login/', views.login),
url(r'^app1/', include('app1.urls')),
] #/app1/urls.py
from django.conf.urls import url
from app1 import views urlpatterns = [
url(r'^press/list', views.presslist),
url(r'^press/del', views.pressdel),
url(r'^press/add', views.pressadd),
url(r'^press/edit/', views.pressedit),
]
4.分组与命名分组
分组是在做什么? 我们传参可以使用get中的url携带参数 ,我们还能用分组直接获得参数传给视图函数 ,方便了不少呢
1).分组(肯定是正则的分组, 一组一个参数 ,参数仅仅能传递str类型)
#urls.py中 url(r'^press/del/(\d+)/', views.pressdel), #使用正则匹配一个分组 #views.py中
def pressdel(request, del_id): #接收url中的位置参数
models.presslist.objects.get(pk=del_id).delete()
return redirect('/app1/press/list')
#html中
<a>href="/app1/press/del/{{ obj.pk }}/"><i class="fa fa-remove" aria-hidden="true"></i></a> #点击时可以触发url
2).命名分组 ,和分组的区别就是使用的是关键字参数 ,可以不考虑顺序传递参数了
#urls.py中 url(r'^press/del/?P<del_id>(\d+)/', views.pressdel), #使用正则匹配一个分组 #views.py中
def pressdel(request, del_id): #接收url中的位置参数
models.presslist.objects.get(pk=del_id).delete()
return redirect('/app1/press/list')
#html中
<a>href="/app1/press/del/{{ obj.pk }}/"><i class="fa fa-remove" aria-hidden="true"></i></a> #点击时可以触发url
3).命名分组之默认值分组 ,默认值分组的意义是什么? 访问不带参数时的默认值 ,如下面的情况
#urls.py文件
url(r'^blog/page/$', views.blog), #访问首页没有参数的时候 ,视图函数中num=9999
url(r'^blog/page/(?P<num>[0-9]{1,2})', views.blog), #访问带页码的参数时 ,视图函数会使用分组中的num值
#views.py
def blog(request,num=''):
5.路由的别名
场景: 重新规划了一下urls中的正则匹配地址 ,此时视图函数与模板中写死的跳转就都变了 ,那么改动实在太多了 ,使用路由别名! 每个url的正则无论如何变化 ,他的别名都不会变化
1).静态别名 ,就是url中没有携带参数(反向解析就是仅关注别名 ,别名后面如何不用管这就是反向解析)
视图函数中使用reverse()函数解析 ,模板中使用{% url '别名' %}解析
# urls.py文件
url(r'^halias/$', views.halias, name='hs'),
url(r'^ralias/$', views.ralias, name='rs'), # views.py文件的redirect
def halias(request):
return render(request, 'test.html') def ralias(request):
return redirect(reverse('rs')) # html文件
< a href = "{% url 'hs' %}" > 刷新操作 < / a >
2).动态别名 ,就是url中夹带了参数 ,反向解析的时候有点不同 ,其中分为参数为位置参数或者是关键字参数
####位置参数解析
#urls.py文件
url(r'^halias/([0-9]{1,2})/(..)/$', views.halias,name='hs'), #在views.py文件redirect(reverse)
def halias(request,c1,c2):
if c1 == '':
return redirect(reverse('hs',args=('','op')))
return render(request,'test.html',{'c1':c1,'c2':c2}) #在html文件
<a href="{% url 'hs' '12' '12' %}">刷新操作</a>
####关键字参数解析
#urls.py文件
url(r'^halias/([0-9]{1,2})/(..)/$', views.halias,name='hs'), #在views.py文件redirect(reverse)
def halias(request,c1,c2):
if c1 == '1':
return redirect(reverse('hs',kwargs={c1:'34',c2:'op'}))
return render(request,'test.html',{'c1':c1,'c2':c2}) #在html文件
<a href="{% url 'hs' c1='12' c2='12' %}">刷新操作</a>
6.路由命名空间
场景: 反向解析虽然好用, 但是如果多个app下出现了重名的解析name模板与视图中怎么办?到底解析哪一个? 使用命名空间 ,在跟urls.py的文件中设定命名空间
#project/urls.py文件
urlpatterns = [
url(r'^app01/', include('app01.urls',namespace='ap1')),
url(r'^app02/', include('app02.urls',namespace='ap2')),
]
#html文件引入别名改动
<p>
<a href="{% url 'ap1:ns' 参数1 参数2... %}">命名空间测试刷新当前页</a>
</p>
#views.py重定向使用别名时
....
return redirect(reverse('ap1:cbs',arg...))
...
7.url相关规范
1)路由要在跟路由处完成分发 ,避免路由表过大
2)路由分发时标注命名空间 ,防止不同app下有重名路由
3)每个app下每条路由都要有别名 ,防止url变化引起大规模改动
django3-路由系统进阶的更多相关文章
- Django进阶(路由系统、中间件、缓存、Cookie和Session、Ajax发送数据
路由系统 1.每个路由规则对应一个view中的函数 url(r'^index/(\d*)', views.index), url(r'^manage/(?P<name>\w*)/(?P&l ...
- day19 Dgango进阶 路由系统及 ORM 详解
完成一个完整的网页服务,需要有以下: 再次回顾一下Django 的完成开发流程: 一些值的获取: 对于性别,为互斥属性: 爱好则为多选: 需要使用新的方法 getlist 来获取多个爱好: 单选下拉框 ...
- 简简单单的Vue3(插件开发,路由系统,状态管理)
既然选择了远方,便只顾风雨兼程 __ HANS许 系列:零基础搭建前后端分离项目 系列:零基础搭建前后端分离项目 插件 路由(vue-router) 状态管理模式(Vuex) 那在上篇文章,我们讲了, ...
- python 全栈开发,Day112(内容回顾,单例模式,路由系统,stark组件)
一.内容回顾 类可否作为字典的key 初级 举例: class Foo(object): pass _registry = { Foo:123 } print(_registry) 执行输出: {&l ...
- django框架--路由系统
目录 一.路由系统理解 二.路由系统功能划分 三.路由表创建 创建工具 二级路由 路由别名 动态路由及重定向 四.自定义错误页面 五.图示路由系统在框架中的定位 六.路由系统的进阶想法 一.路由系统理 ...
- django基础篇02-url路由系统
django的路由系统: 一.基本用法: 1.path('index', views.index), # 通过类的方式创建url映射 2.path('home', views.Home.as_view ...
- ASP.NET Core的路由[2]:路由系统的核心对象——Router
ASP.NET Core应用中的路由机制实现在RouterMiddleware中间件中,它的目的在于通过路由解析为请求找到一个匹配的处理器,同时将请求携带的数据以路由参数的形式解析出来供后续请求处理流 ...
- ASP.NET Web API路由系统:路由系统的几个核心类型
虽然ASP.NET Web API框架采用与ASP.NET MVC框架类似的管道式设计,但是ASP.NET Web API管道的核心部分(定义在程序集System.Web.Http.dll中)已经移除 ...
- ASP.NET Web API路由系统:Web Host下的URL路由
ASP.NET Web API提供了一个独立于执行环境的抽象化的HTTP请求处理管道,而ASP.NET Web API自身的路由系统也不依赖于ASP.NET路由系统,所以它可以采用不同的寄宿方式运行于 ...
- .NET/ASP.NET Routing路由(深入解析路由系统架构原理)
阅读目录: 1.开篇介绍 2.ASP.NET Routing 路由对象模型的位置 3.ASP.NET Routing 路由对象模型的入口 4.ASP.NET Routing 路由对象模型的内部结构 4 ...
随机推荐
- 浅谈Httpmodules
HttpModule是ASP.NET过滤器,可以理解为HTTP请求的必经之地我们只要实现IHttpModule接口,就可以取代HttpModule namespace BookShop.Handler ...
- Supply Initial Data提供初始数据 (EF)
Open the Updater.cs (Updater.vb) file, located in the MySolution.Module project's Database Update fo ...
- docker redis使用
启动方式一:docker默认启动redis 1.拉取镜像 docker pull redis:lastest (若不使用版本号,如docker pull redis,默认拉取最新镜像) 2.启动red ...
- 【C#】学习笔记(4) 值类型和引用类型相关(Null相关)
Reference and Value Types Value Types(值类型): struct(结构体) 独立的实例或者是拷贝 值的改变不会影响其它拷贝 值就是它所代表的信息 没有引用,所以不可 ...
- kali安装vmtool后依旧无法拖拽文件,复制粘贴,解决办法
本文链接:https://blog.csdn.net/Key_book/article/details/80310235命令行下 执行 apt-get install open-vm-tools-de ...
- 更改 undo_retention 时,Lob retention 不更改 (Doc ID 563470.1)
Lob retention not changing when undo_retention is changed (Doc ID 563470.1) APPLIES TO: Oracle Datab ...
- Python对MongoDB增删改查
pip install pymongo import pymongo # 建立连接 client = pymongo.MongoClient() # 指定数据库 (不存在则会新建) db = clie ...
- Java学习笔记(8)---Scanner类,浅谈继承
1.Scanner类: a.定义: java.util.Scanner 是 Java5 的新特征,我们可以通过 Scanner 类来获取用户的输入. Scanner s = new Scanner(S ...
- Codeforces Round #600 (Div. 2)
传送门 A. Single Push 直接乱搞即可. Code /* * Author: heyuhhh * Created Time: 2019/11/16 22:36:20 */ #include ...
- misc-适合作为桌面
今年黑盾杯的misc之一,居然是两年前的世安杯原题 神器stegsolve获得二维码 用QR-Research获得一段十六进制 用winhex填充数据 ascll->hex(之前只做到这里,看 ...