脚本专栏 
首页 > 脚本专栏 > 浏览文章

Django中URL的参数传递的实现

(编辑:jimmy 日期: 2025/1/20 浏览:3 次 )

在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方式传递指定参数,语法为: ("htmlcode">

url(r'^articles/("htmlcode">
url(r'^articles/([0-9]{4})/$', views.year_archive, name='news-year-archive'),

Django在不同的层次也提供了一些工具来实现URL的反向解析。

  1. 在template中:使用url标签
  2. 在python中:使用django.core.urlresolvers.reverse()函数
  3. 在更高层次处理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/("htmlcode">
# -*- 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>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

上一篇:使用 python pyautogui实现鼠标键盘控制功能
下一篇:Python 实现遥感影像波段组合的示例代码