Django中URL的参数传递的实现
作者:静以修身养心 发布时间:2022-12-24 13:53:25
在Django中有非常强大的URL模块,可以按照开发者的想法来制定清晰的URL,同时支持正则表达式。此外,在URL中还可以传递参数。
1. Django处理请求的方式
1) Django通过URLconf模块来进行判断。通常情况下,这就是ROOT_URLCONF配置的价值,但是如果请求携带了一个urlconf的属性(通常被中间件设置),那么这个被携带的urlconf将会替代ROOT_URLCONF的配置。
2) Django会调用Python模块并寻找各种urlpatterns。这是一个属于django.conf.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})/$', views.month_archive),
那么year,month将会对应views传递过来的year,month的值,而后面紧跟的则代表正则表达匹配的模式。
3. URL的反向解析
通常来说在处理完一个表单之后,网页会发生跳转。通常写URL我们都避免硬编码,这样不方便后期的调整。通常我们需要从URL获取两种内容,最主要是view能够通过URL获取一些标识并处理,另一些信息则是传递过来的参数。
Django提供了一种解决方案,URL mapper是与URL设计一一对应。你可以通过URLconf来实现,并反向使用它。例如,
由用户通过浏览器发起URL请求,调用view,并将URL中的参数传递给view
通过view并附上相应参数,找到相应匹配的URL。
后者我们称之为对URLs的反向解析。反向解析的例子,
url(r'^articles/([0-9]{4})/$', views.year_archive, name='news-year-archive'),
Django在不同的层次也提供了一些工具来实现URL的反向解析。
在template中:使用url标签
在python中:使用django.core.urlresolvers.reverse()函数
在更高层次处理model实例时,可以使用get_absolute_url()方法
4. 利用URL来完成Device,Line表的增加功能
对于信息系统,我们可以把Node,Device, Line都看成是一种资源,对其中任何一种要素的修改,都是对资源的修改,只是会落实到不同的表中,但是在程序中可以一样看到。现在,我们就基于上一节的代码做些修改。
1)修改URL的配置,将原来的add对应的url进行扩充
urls.py:
from django.conf.urls import url
from django.contrib 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':
instance.node_signer = request.user
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>{{ item.node_name }}</td>
<td>{{ item.node_address }}</td>
<td>{{ item.node_type }}</td>
</tr>
{% endfor %}
</table>
</body>
</html>
来源:https://blog.csdn.net/alex_chen_16/article/details/50850435
![](https://www.aspxhome.com/images/zang.png)
![](https://www.aspxhome.com/images/jiucuo.png)
猜你喜欢
- 去除数字,特殊字符,只保留汉字import res = '1123*#$ 中abc国'str = re.sub('[
- 1.实现的思路(1)首先使用一个处理画框的程序,将图片中的有车和无车的停车位给画出来,并且保存坐标(如果画错了,将鼠标移至要删除的框中,右击
- 本文分析了PHP7新特性之抽象语法树(AST)带来的变化。分享给大家供大家参考,具体如下:这里大部分内容参照 AST 的 RFC 文档而成:
- 这篇文章主要介绍了python多进程间通信代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可
- def quick_sort(ls): return [] if ls == [] else quick_sort([y for y in
- 注:本文针对单个服务器上多块GPU的使用,不是多服务器多GPU的使用。在一些实验中,由于Batch_size的限制或者希望提高训练速度等原因
- 本文实例为大家分享了python实现图像边缘检测的具体代码,供大家参考,具体内容如下任务描述背景边缘检测是数字图像处理领域的一个常用技术,被
- asp抓取网页。偶要实现实实更新天气预报。利用了XMLHTTP组件,抓取网页的指定部分。很多小偷查询都是使用这个方法来实现的。需要分件htm
- 在做一些工作的时候,有时候会涉及到给图片加上水印,这个如果手动添加的话,效率太低了,通常选择代码完成。下面这个是给图像添加文字水印(图片水印
- 我们经常会有对图像边缘做扩展的需求.比如希望卷积后得到的矩阵大小不变希望改变图像大小,但是不改变宽高比opencv实现opencv中使用co
- 在使用Python处理数据时,经常需要对数据筛选。这是在对时间筛选时,判断两列时间是否相差一年,如果是,则返回符合条件的所有列。data原始
- 如下所示:来源:https://blog.csdn.net/qq_33485434/article/details/80604370
- 在js中this的指向对于新手来说一定是个难题,但是如果你真正理解了的话,也就没什么问题啦,下面就来讲讲this吧。JS中,this的值取决
- 其实这个话题已经在侧面写了好几篇深刻反思,用我自己几年工作实践的体会来看,性格决定了将来的发展。某些特质虽然可以掩饰,但在这之上必然不可能有
- 框架中(iframe)的数据。只要协议、域名、端口有任何一个不同,都被当作是不同的域。下表给出了相对http://store.company
- 编码问题response = requests.get(URL, params=params, he
- 问题:连续或者单个窗体,如何打印当前显示的记录?当前窗体还有对应的子窗体,也要一起打印出来我在一个窗体里有一个单号,大子窗体里有几组数据,我
- 本文实例讲述了PHP会话控制技巧。分享给大家供大家参考,具体如下:Demo1.php<form method="get&qu
- 前言TensorFlow目前在移动端是无法training的,只能跑已经训练好的模型,但一般的保存方式只有单一保存参数或者graph的,如何
- 情景描述在项目开发过程中,不同项目阶段可能会有不同的分支,当创建好一个分支后,就需要将代码切换到这个分支上进行代码同步,例如将当前 orig