反向传递视图中的kwargs;django 1.5

3 投票
1 回答
7540 浏览
提问于 2025-04-17 17:33

作为一个刚开始学习Django的新手,我遇到了一点小问题:

html代码:

<li><a href="{% url 'dyn_display' category='first'%}">first</a></li>
<li><a href="{% url 'dyn_display' category='second'%}">second</a></li>
<li><a href="{% url 'dyn_display' category='third'%}">third</a></li>

urlconf.py

url(r'(?P<category>[a-z]+)$', 'display', name='dyn_display')

view.py

def courses_display(request, category):
    return render_to_response('display/basic.html', {category: 'in'}, context_instance=RequestContext(request))

还有basic.html的一部分,这样你可以理解我为什么需要那个分类变量

basic.html

<div class="accordion" id="accordion2">
    <div class="accordion-group">
        <div class="accordion-heading">
            <a class="accordion-toggle" data-toggle="collapse" data-parent="#accordion2" href="#collapseFirst">
                <strong>First</strong>
            </a>
        </div>
        <div id="collapseFirst" class="accordion-body collapse {{ first }}">
             <div class="accordion-inner">
                 ...
             </div>
         </div>
     </div>
     <div class="accordion-group">
         <div class="accordion-heading">
             <a class="accordion-toggle" data-toggle="collapse" data-parent="#accordion2" href="#collapseSecond">
                 <strong>Second</strong>
             </a>
         </div>
         <div id="collapseSecond" class="accordion-body collapse {{ second }}">
             <div class="accordion-inner">
                 ...
             </div>
         </div>
     </div>
     <div class="accordion-group">
         <div class="accordion-heading">
             <a class="accordion-toggle" data-toggle="collapse" data-parent="#accordion2" href="#collapseThird">
                 <strong>Third</strong>
             </a>
         </div>
         <div id="collapseThird" class="accordion-body collapse {{ third }}">
             <div class="accordion-inner">
                 ...
             </div>
         </div>
      </div>
  </div>

因为整个页面都是用Bootstrap和JQuery做的,所以最后的URL部分

some/url/first

some/url/second

some/url/third

看起来有点丑,因为手风琴元素让我可以在不重新加载页面的情况下展开和收起相应的内容。所以我的问题是:有没有办法反向传递一个关键字参数(kwarg),这个参数会在视图中使用,而不是用来确定reverse()中的URL?

我想知道怎么才能像这样获取URL some/url/,同时又能把第一个.html页面中的关键字参数传递给视图?

1 个回答

8

你可以这样做:

如果这是你的网址:

url(r'(?P<category>[a-z]+)$', 'display', name='dyn_display')
reverse('dyn_display', kwargs={'category': 'first'})

要进行重定向,你可以在你的视图中这样使用:

from django.http import HttpResponseRedirect
return HttpResponseRedirect(reverse('dyn_display', kwargs={'category': 'first'}))

如果这是你的网址:

url(r'$', 'display', name='dyn_dysplay')
reverse('dyn_display')

要进行重定向,你可以在你的视图中这样使用:

from django.http import HttpResponseRedirect
return HttpResponseRedirect(reverse('dyn_display'))

如果你想让一个视图能够接收一个可选的值,你需要两个网址:

url(r'$', 'display', name='dyn_optional_display')    
url(r'(?P<category>[a-z]+)$', 'display', name='dyn_display')

然后你的视图可以是:

def courses_display(request, category=None):
    ctx = {}
    if category:
        ctx.update({category: 'in'})
    return render_to_response('display/basic.html', ctx,    context_instance=RequestContext(request))

撰写回答