博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
第26天,Django之include本质
阅读量:6344 次
发布时间:2019-06-22

本文共 4925 字,大约阅读时间需要 16 分钟。

目录

一、 URL name详解    向视图传递额外的参数    利用reverse函数反向生成URL    对有参数的url设置name二、include路由转发    传递额外的参数给include()三、URL命名空间四、include()本质

一、 URL name详解

from django.conf.urls import urlfrom django.contrib import adminfrom calc import views as calc_views  urlpatterns = [    url(r'^add/$', calc_views.add, name='add'),    url(r'^add/(\d+)/(\d+)/$', calc_views.add2, name='add2'),    url(r'^admin/', admin.site.urls),]

url(r'^add/$', calc_views.add, name='add'), 这里的 name='add' 是用来干什么的呢?

简单说,name 可以用于在 templates, models, views ……中得到对应的网址,相当于“给网址取了个名字”,只要这个名字不变,网址变了也能通过名字获取到。

模板中可以这样利用name

不带参数的:{% url 'name' %}带参数的:参数可以是变量名{% url 'name' 参数 %}

结合上面的urls.py

不带参数:添加上面模板经过渲染后的标签是这样的:添加带参数的:link经过渲染后:link

当 urls.py 进行更改,前提是不改 name(这个参数设定好后不要轻易改),获取的网址也会动态地跟着变,比如改成:

url(r'^new_add/(\d+)/(\d+)/$', calc_views.add2, name='add2'),

注意: add 变成了 new_add,但是后面的 name='add2'没改,这时 {% url 'add2' 4 5 %} 就会渲染对应的网址成/new_add/4/5/

向视图传递额外的参数

url()中允许你传递一个Python字典作为额外的关键字参数给视图函数。

from django.conf.urls import urlfrom . import viewsurlpatterns = [    url(r'^blog/(?P
[0-9]{4})/$', views.year_archive, {'foo': 'bar'}),]

在上面的例子中,对于/blog/2005/请求,Django将调用views.year_archive(request, year='2005', foo='bar')。

注意:命名关键字参数和在字典中传递的额外参数要避免重名。

利用reverse函数反向生成URL

urls.py

from app01 import views as viewsurlpatterns = [    url(r'^login/',views.login),    url(r'^index/first/',views.index,name='first'),]

views.py

from django.shortcuts import render,HttpResponse,redirectfrom django.urls import reversedef login(request):    url = reverse('first')    print(url)  # 打印结果:/index/first/    return redirect(url)def index(request):    return HttpResponse('index/first')

对有参数的url设置name

urls.py:

from django.conf.urls import urlfrom . import viewsurlpatterns = [    #...    url(r'^articles/([0-9]{4})/$', views.year_archive, name='news-year-archive'),    #...]

模板代码中使用:

2012 Archive   # 注意模版语言的用法,注意参数的传递方法{# Or with the year in a template context variable: #}

views.py视图函数:

from django.urls import reversefrom django.http import HttpResponseRedirectdef redirect_to_year(request):    # ...    year = 2006    # ...注意参数的传递方法    return HttpResponseRedirect(reverse('news-year-archive', args=(year,)))

二、include路由转发

通常,我们会在每个app里,各自创建一个urls.py路由模块,然后从根路由出发,将app所属的url请求,全部转发到相应的urls.py模块中。

创建两个app:cmdb和openstack,并分别在这两个app目录下创建urls.py文件

from django.conf.urls import url,include        # 需要先导入include函数from django.contrib import adminfrom app01 import viewsurlpatterns = [    # url(r'^admin/', admin.site.urls),    url(r'^cmdb/',include('cmdb.urls')),    url(r'^openstack/',include('openstack.urls')),]

传递额外的参数给include()

参数会传递给include指向的urlconf中的每一行,例如,下面两种URLconf配置方式在功能上完全相同:

配置一:

# main.pyfrom django.conf.urls import include, urlurlpatterns = [    url(r'^blog/', include('inner'), {'blogid': 3}),]# inner.pyfrom django.conf.urls import urlfrom mysite import viewsurlpatterns = [    url(r'^archive/$', views.archive),    url(r'^about/$', views.about),]

配置二:

# main.pyfrom django.conf.urls import include, urlfrom mysite import viewsurlpatterns = [    url(r'^blog/', include('inner')),]# inner.pyfrom django.conf.urls import urlurlpatterns = [    url(r'^archive/$', views.archive, {'blogid': 3}),    url(r'^about/$', views.about, {'blogid': 3}),]

注意,只有当你确定被include的URLconf中的每个视图都接收你传递给它们的额外的参数时才有意义,否则其中一个以上视图不接收该参数都将导致错误异常。

三、URL命名空间

URL命名空间可以保证反查到唯一的URL。

urls.py

from django.conf.urls import url,includeurlpatterns = [    url(r'^cmdb/',include('cmdb.urls',namespace='cmdb')),    url(r'^openstack/',include('openstack.urls',namespace='openstack')),]

cmdb/urls.py

from django.conf.urls import urlfrom cmdb import viewsurlpatterns = [    url(r'host/',views.host,name='host'),]

在模板中使用

跳转

在视图中利用reverse()函数反向生成url

from django.shortcuts import render,HttpResponse,redirectfrom django.urls import reversedef host(request):    url = reverse('cmdb:host')    print(url)      # 打印结果:/cmdb/host/    return HttpResponse('cmdb.host')

注意:namespace与name在模板文件和视图函数中使用的时候要用冒号分隔,如:“cmdb:host”

四、include()本质

include()函数实际上就是返回一个元组:([], None, None)

第一个元素可以是一个列表,列表中盛放url()子路由配置;
第二个元素是app_name,可以为None;
第三个元素是namespace,需要反向生成url时,可根据需求填写;

所以urls.py也可以这样写:

from django.conf.urls import urlurlpatterns = [    url(r'^openstack/',([],None,None,),]

直接用一个元组替代include()

如下,直接进行子路由分发:

from django.conf.urls import url,includefrom cmdb import views as cviewsfrom app01 import viewsurlpatterns = [    # url(r'^admin/', admin.site.urls),    url(r'^index/',views.index,name='index'),    url(r'^cmdb/',include('cmdb.urls',namespace='cmdb')),    # url(r'^openstack/',include('openstack.urls',namespace='openstack')),    url(r'^openstack/',([        url(r'^host/',cviews.host,name='host'),        url(r'^host/add/',cviews.addhost,name='addhost'),        url(r'^host/(\d+)/change',cviews.changehost,name='changehost'),    ],None,'openstack')),]

以上元组中的'openstack',就相当于include()函数的namespace='openstack'

转载地址:http://djjla.baihongyu.com/

你可能感兴趣的文章
【实用】面对枯燥的源码,如何才能看得下去?
查看>>
智库说 | 徐远:数字时代的城市潜力
查看>>
《JSP极简教程》jsp c:forEach用法
查看>>
WebSocket详解(六):刨根问底WebSocket与Socket的关系
查看>>
用 Go 写一个轻量级的 ssh 批量操作工具
查看>>
网站设计之合理架构CSS 架构CSS
查看>>
OTP 22.0 RC3 发布,Erlang 编写的应用服务器
查看>>
D语言/DLang 2.085.1 发布,修复性迭代
查看>>
感觉JVM的默认异常处理不够好,既然不好那我们就自己来处理异常呗!那么如何自己处理异常呢?...
查看>>
Java 基础 之 算数运算符
查看>>
Windows下配置安装Git(二)
查看>>
一个最简单的基于Android SearchView的搜索框
查看>>
铁路开通WiFi“钱景”不明
查看>>
Nutanix领衔的超融合能带来新存储黄金时代吗?
查看>>
Facebook申请专利 或让好友及陌生人相互拼车
查看>>
电力“十三五”规划:地面光伏与分布式的分水岭
查看>>
美联社再告FBI:要求公开请黑客解锁iPhone花费
查看>>
三星电子出售希捷和夏普等四家公司股份
查看>>
任志远:当云计算遇上混合云
查看>>
思科联手发那科 用物联网技术打造无人工厂
查看>>