选择django中的后向关联

时间:2018-02-16 05:11:32

标签: django django-models

我正在写一个Django项目。

courses/models.py

class Category(models.Model):
    title = models.CharField(max_length=50)

class Language(models.Model):
    category = models.ForeignKey(Category, on_delete=models.CASCADE)
    title = models.CharField(max_length=50)

class Course(models.Model):
    name = models.CharField(max_length=250)
    language = models.ForeignKey(Language, on_delete=models.CASCADE)

我想获取所有Category的列表,然后遍历指定类别的每个Language

class Courses(ListView):
    template_name = 'courses/index.html'
    model = Course
    context_object_name = 'courses'

    def get_context_data(self, **kwargs):
        context = super(Courses, self).get_context_data(**kwargs)
        categories = Category.objects.all()
        context['categories'] = categories
        return context
模板courses/index.html中的

我想根据类别

显示语言列表
{% for category in categories %}
    {{ category.title }}
    <li>lis of languages in this category</li>
{% endfor %}

如何循环使用后向关联数据?

2 个答案:

答案 0 :(得分:5)

Django创建了一个可以通过modelname_set密钥在模板中访问的关系。

在你的情况下,你必须迭代: category.language_set.all

{% for category in categories %}
    {{ category.title }}
    {% for language in category.language_set.all %}
        <li>{{ language.title }}</li>
    {% endfor %}
{% endfor %}

答案 1 :(得分:-1)

_set这样做。 例如。在您的情况下,此代码必须工作:

{%for language in language.language_set.all%}     

  • {{language.title}}
  • {%endfor%}