我一直试图做这个嵌套循环几个小时,但到目前为止我的结果都没有。以下是我到目前为止的情况:
的index.html
{% for category in categories %}
<div class="col-md-12 column category list-group">
<p><b>{{ category.name }}</b></p>
{% for subcategory in subcategories %}
<div class="list-group-item">
<h5 class="mb-1"><a href="{% url 'subcategory_threads' subcategory.id %}">{{ subcategory.name }}</a></h5>
<small>{{ subcategory.description }}</small>
<small>{{ subcategory.count_threads }}</small>
</div>
{% endfor %}
</div>
{% endfor %}
views.py
class IndexView(ListView):
template_name = 'myForum/index.html'
context_object_name = 'SubCategory_list'
queryset = SubCategory.objects.all()
def get_context_data(self, **kwargs):
context = super(IndexView, self).get_context_data(**kwargs)
context['categories'] = Category.objects.all()
context['subcategories'] = SubCategory.objects.all()
return context
models.py
class Category(models.Model):
name = models.CharField(max_length=255)
def __str__(self):
return self.name
class SubCategory(models.Model):
name = models.CharField(max_length=255)
description = models.CharField(max_length=255)
category = models.ForeignKey('Category', default=0)
def __str__(self):
return self.name
输出 Output
我的问题是SubCategory - News,属于Infromation,类别Off-Topic属于General。由于某种原因,循环显示所有子类别,我无法弄清楚如何将其缩小到当前类别。
答案 0 :(得分:0)
您可以将内循环更改为:
{% for subcategory in category.subcategory_set.all %}
这将遍历当前类别的子类别。
由于您在外部循环中循环类别,因此可以在列表视图中更改查询集以使用Category
模型。您可以通过预取子类别来减少查询数量。
看起来好像你可以删除get_context_data
方法,因为列表视图已经在模板上下文中提供了查询集。
class IndexView(ListView):
template_name = 'myForum/index.html'
context_object_name = 'catrgories'
queryset = Category.objects.all().prefetch_related('subcategory_set')