我是Django的新手,似乎无法找到问题的解决方案
我收到以下错误
Reverse for 'todo_list' with arguments '()' and keyword arguments
'{'cid': 1}' not found. 1 pattern(s) tried: ['todo/(?P<cid>)/']
1 {% extends "base.html" %}
2 {% block nav_title %} Company Batches {% endblock nav_title %}
3 {% block content %}
4 <div class="jumbotron">
5
6 {% for obj in object_list %}
7 <a href={% url 'todo_list' cid=obj.company.id%} class="href-nostyle">
8 <div class="container">
9 <div class="jumbotron" style="background:white">
10 <div class="text-center">
11 <h1>{{ obj.company }}<br>
12 <small>{{ obj.job }}</small>
13 </h1>
14 </div>
15 </div>
16 </div>
17 </a>
此模板位于名为 company_batches 的应用中,我尝试使用href将用户导航到待办事项应用
我的网址标记是
{% url 'todo_list' cid=obj.company.id%}
我的主要urls.py
urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^$', home, name='home'),
url(r'^batches/', include('company_batches.urls')),
url(r'^todo/', include('todo.urls'), name='todo')
]
待办事项/ urls.py
urlpatterns = [
url(r'^$', ToDoCreateView.as_view(), name='todo_create'),
url(r'^(?P<cid>)/', ToDoListView.as_view(), name='todo_list'),
]
相关的views.py
class ToDoListView(ListView,):
template_name = 'todo/todo_list.html'
def get_context_data(self, *args, **kwargs):
context = super(ToDoListView, self).get_context_data(*args, **kwargs)
return context
def get_queryset(self, cid):
return ToDoList.objects.filter(company=self.cid)
我无法弄清楚我做错了什么,一些指导会非常感激
答案 0 :(得分:2)
你的正则表达式被打破了;它没有任何匹配的字符。看起来你想捕获一个数字PK,应该是:
r'^(?P<cid>\d+)/
答案 1 :(得分:2)
这里有几点需要注意。
正则表达式,可能是这里的实际问题
捕获cid
中的url regex
不包含正确的捕获组。由于它是一个ID,因此您只应使用\d+
url(r'^(?P<cid>\d+)/', ToDoListView.as_view(), name='todo_list'),
关闭网址正则表达式
当前网址不包含结束标志。如果网址实际上在/app/<id>/
之后结束,则您很可能会使用美元符号$
关闭正则表达式。
url(r'^(?P<cid>\d+)/$', ToDoListView.as_view(), name='todo_list'),
命名空间使用
您正在使用name
,同时包含todo
个应用网址。要正确使用命名空间,您应该在todo/
网址中删除该名称并添加
namespace
到包含。
url(r'^todo/', include('todo.urls', namespace='todo'))
现在,您可以在模板中使用命名空间
{% url 'todo:todo_list' cid=obj.company.id %}