Django中URL的参数传递的实现
在Django中有⾮常强⼤的URL模块,可以按照开发者的想法来制定清晰的URL,同时⽀持正则表达式。此外,在URL中还可以传递参数。
1. Django处理请求的⽅式
1) Django通过URLconf模块来进⾏判断。通常情况下,这就是ROOT_URLCONF配置的价值,但是如果请求携带了⼀个urlconf的属性(通常被中间件设置),那么这个被携带的urlconf将会替代ROOT_URLCONF的配置。
2) Django会调⽤Python模块并寻各种urlpatterns。这是⼀个属于f.urls.url()实例的python列表。
3) Django会遍历每个URL pattern,⾃上⽽下,并且选取收割匹配请求URL的pattern。
4)⼀旦匹配某个url pattern的正则表达式,Django将导⼊并调⽤相关的view(这是⼀个简单的python函数,或者是⼀个class-based view)
这个view将会传递下列参数:
⼀个HttpRequest的实例
如果匹配了URL中⼀个no named group,那么参数将会按根据URL中的位置⼀⼀对应
如果匹配了URL中⼀个named group,且参数传递是通过named group来匹配的,那么参数将会被指定的kwargs代替。
5)如果没有任何⼀个正则表达式被匹配,那么Django会抛出异常,并报错。
2.URL中的named group
URL可以通过named group⽅式传递指定参数,语法为: (?P<name>pattern), name 可以理解为所要传递的参数的名
称,pattern代表所要匹配的模式。例如,
url(r'^articles/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})/$', h_archive),
那么year,month将会对应views传递过来的year,month的值,⽽后⾯紧跟的则代表正则表达匹配的模式。
3. URL的反向解析
通常来说在处理完⼀个表单之后,⽹页会发⽣跳转。通常写URL我们都避免硬编码,这样不⽅便后期的调整。通常我们需要从URL获取两种内容,最主要是view能够通过URL获取⼀些标识并处理,另⼀些信息则是传递过来的参数。
Django提供了⼀种解决⽅案,URL mapper是与URL设计⼀⼀对应。你可以通过URLconf来实现,并反向使⽤它。例如,
1. 由⽤户通过浏览器发起URL请求,调⽤view,并将URL中的参数传递给view
2. 通过view并附上相应参数,到相应匹配的URL。
后者我们称之为对URLs的反向解析。反向解析的例⼦,
url(r'^articles/([0-9]{4})/$', ar_archive, name='news-year-archive'),
Django在不同的层次也提供了⼀些⼯具来实现URL的反向解析。
1. 在template中:使⽤url标签
2. 在python中:使⽤verse()函数
3. 在更⾼层次处理model实例时,可以使⽤get_absolute_url()⽅法
4. 利⽤URL来完成Device,Line表的增加功能
对于信息系统,我们可以把Node,Device, Line都看成是⼀种资源,对其中任何⼀种要素的修改,都是对资源的修改,只是会落实到不同的表中,但是在程序中可以⼀样看到。现在,我们就基于上⼀节的代码做些修改。
1)修改URL的配置,将原来的add对应的url进⾏扩充
urls.py:
f.urls import url
ib import admin
import echo.views
urlpatterns = [
url(r'^admin/', admin.site.urls),
#内容显⽰,并通过定义name,来进⾏反向解析
url(r'^lists/(?P<table>\w+)/$', echo.views.lists, name='lists'),
#增加内容
url(r'^add/(?P<table>\w+)/$', echo.views.add, name='add'),
]
2) 修改views的函数的参数,在request后加⼊table,使该函数能够⽤于所有表格。request是views函数中必须要有的参数。views.py:
# -*- coding: UTF-8 -*-
from .models import Node,Line,Device
from forms import NodeForm,LineForm,DeviceForm
from django.shortcuts import render, redirect
# Create your views here.
def lists(request, table):
#从根据不同的请求,来获取相应的数据,并跳转⾄相应页⾯
if table == 'node':
data = Node.objects.all()
list_template = 'node_list.html'
if table == 'line':
data = Line.objects.all()
list_template = 'line_list.html'
if table == 'device':
data = Device.objects.all()
list_template = 'device_list.html'
#建⽴context字典,将值传递到相应页⾯
context = {
'data': data,
}
#跳转到相应页⾯,并将值传递过去
return render(request,list_template,context)
def add(request, table):
#根据提交的请求不同,获取来⾃不同Form的表单数据
if table == 'node':
form = NodeForm(request.POST or None)
if table == 'line':
form = LineForm(request.POST or None)
if table == 'device':
form = DeviceForm(request.POST or None)
#判断form是否有效
if form.is_valid():
#创建实例,需要做些数据处理,暂不做保存
instance = form.save(commit=False)
#将登录⽤户作为登记⼈
if table == 'node':
django admin 自定义页面
if table == 'line':
instance.line_signer = request.user
if table == 'device':
instance.device_signer = request.user
#保存该实例
instance.save()
#跳转⾄列表页⾯,配合table参数,进⾏URL的反向解析
return redirect('lists', table=table)
#创建context来集中处理需要传递到页⾯的数据
context = {
'form': form,
}
#如果没有有效提交,则仍留在原来页⾯
return render(request, 'add.html', context)
3)在template中建⽴相关页⾯:
add.html:
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title></title>
</head>
<body>
<form method='POST' action=''>{% csrf_token %} {{ form }}
<input type='submit' value='提交' />
</form>
</body>
</html>
device_list.html:
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title></title>
</head>
<body>
<table>
<tr>
<th>设备名称</th>
<th>设备型号</th>
</tr>
{% for item in data %}
<tr>
<td>{{ item.device_caption }}</td>
<td>{{ item.device_type }}</td>
</tr>
{% endfor %}
</table>
</body>
</html>
line_list.html:
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title></title>
</head>
<body>
<table>
<tr>
<th>线路名称</th>
<th>线路速率</th>
<th>线路类型</th>
</tr>
{% for item in data %}
<tr>
<td>{{ item.line_code }}</td>
<td>{{ item.line_speed }}</td>
<td>{{ item.line_type }}</td>
</tr>
{% endfor %}
</table>
</body>
</html>
node_list.html:
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title></title>
</head>
<body>
<table>
<tr>
<th>节点名称</th>
<th>节点地址</th>
<th>节点类型</th>
</tr>
{% for item in data %}
<tr>
<td>{{ de_name }}</td>
<td>{{ de_address }}</td>
<td>{{ de_type }}</td>
</tr>
{% endfor %}
</table>
</body>
</html>
以上就是本⽂的全部内容,希望对⼤家的学习有所帮助,也希望⼤家多多⽀持。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论