现在的位置: 首页 > 综合 > 正文

URLConf技巧-django

2018年04月30日 ⁄ 综合 ⁄ 共 2534字 ⁄ 字号 评论关闭

一、使用命名组

     使用命名组,能够使代码更加清晰,在做一些复杂模块的时候,只需看一下URLconf就大概知道怎么回事了。
     命名组规则:
     在 Python 正则表达式中,命名的正则表达式组的语法是 (?P<name>pattern) ,这里 name 是组的名字,而 pattern 是匹配的某个模式。   

    例子:

     urlpatterns = patterns('',
                       (r'^showdate/(?P<year>/d{4})/(?P<month>/d{2})/(?P<day>/d{2})/$',Show_date),
)

     这里定义了三个命名组分别是年月日。在模板里根据名称就能很好的组织并处理数据
    
def Show_date(request,mon,year,day):
    html = 'ShowTime: '+year+'year'+' '+month+'Mon'+' '+day+'day'
    html = '%s' % html   
    return HttpResponse(html)

二、理解匹配/分组算法

  

需要注意的是如果在URLconf中使用命名组,那么命名组和非命名组是不能同时存在于同一个
URLconf的模式中的。如果你这样做,Django不会抛出任何错误,但你可能会发现你的URL并没有像你预想的那样匹配正确。具体地,以下是
URLconf解释器有关正则表达式中命名组和非命名组所遵循的算法。

  • 如果有任何命名的组,Django会忽略非命名组而直接使用命名组。

  • 否则,Django会把所有非命名组以位置参数的形式传递。

在以上的两种情况,Django同时会以关键字参数的方式传递一些额外参数。

传递额外的参数到视图函数中

有时你会发现你写的视图函数是十分类似的,只有一点点的不同。比如说,你有两个视图,它们的内容是一致的,除了它们所用的模板不太一样:

# urls.py

from django.conf.urls.defaults import *
from mysite import views

urlpatterns = patterns('',
(r'^foo/$', views.foo_view),
(r'^bar/$', views.bar_view),
)

# views.py

from django.shortcuts import render_to_response
from mysite.models import MyModel

def foo_view(request):
m_list = MyModel.objects.filter(is_new=True)
return render_to_response('template1.html', {'m_list': m_list})

def bar_view(request):
m_list = MyModel.objects.filter(is_new=True)
return render_to_response('template2.html', {'m_list': m_list})

我们在这代码里面做了重复的工作,不够简练。起初你可能会想,通过对两个URL都试用同样的视图,在URL中使用括号捕捉请求,然后在视图中检查并决定使用哪个模板来去除代码的冗余,就像这样:

# urls.py

from django.conf.urls.defaults import *
from mysite import views

urlpatterns = patterns('',
(r'^(foo)/$', views.foobar_view),
(r'^(bar)/$', views.foobar_view),
)

# views.py

from django.shortcuts import render_to_response
from mysite.models import MyModel

def foobar_view(request, url):
m_list = MyModel.objects.filter(is_new=True)
if url == 'foo':
template_name = 'template1.html'
elif url == 'bar':
template_name = 'template2.html'
return render_to_response(template_name, {'m_list': m_list})

这种解决方案的问题还是老缺点,就是把你的URL耦合进你的代码里面了。如果你打算把 /foo/ 改成 /fooey/ 的话,那么你就得记住要去改变视图里面的代码。

优雅的解决方法:使用一个额外的URLconf参数。一个URLconf里面的每一个模式可以包含第三个数据:一个传到视图函数中的关键字参数的字典。

有了这个概念以后,我们就可以把我们现在的例子改写成这样:

# urls.py

from django.conf.urls.defaults import *
from mysite import views

urlpatterns = patterns('',
(r'^foo/$', views.foobar_view, {'template_name': 'template1.html'}),
(r'^bar/$', views.foobar_view, {'template_name': 'template2.html'}),
)

# views.py

from django.shortcuts import render_to_response
from mysite.models import MyModel

def foobar_view(request, template_name):
m_list = MyModel.objects.filter(is_new=True)
return render_to_response(template_name, {'m_list': m_list})

如你所见,这个例子中,URLconf指定了 template_name 。而视图函数则会把它处理成另一个参数而已。

这额外的URLconf参数的技术以最少的麻烦给你提供了向视图函数传递额外信息的一个好方法。

抱歉!评论已关闭.