python给url传参数_Django中URL的参数传递的实现

在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方式传递指定参数,语法为: (?Ppattern), name 可以理解为所要传递的参数的名称,pattern代表所要匹配的模式。例如,

url(r'^articles/(?P[0-9]{4})/(?P[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

#增加内容

url(r'^add/(?P

]

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:

{% csrf_token %}

{{ form }}

device_list.html:

设备名称设备型号

{% for item in data %}

{{ item.device_caption }}{{ item.device_type }}

{% endfor %}

line_list.html:

线路名称线路速率线路类型

{% for item in data %}

{{ item.line_code }}{{ item.line_speed }}{{ item.line_type }}

{% endfor %}

node_list.html:

节点名称节点地址节点类型

{% for item in data %}

{{ item.node_name }}{{ item.node_address }}{{ item.node_type }}

{% endfor %}

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值