繁体   English   中英

html模板中的django外键表字段

[英]django foreign key table fields in html template

我有两个表(文章、评论)使用外键关联一对多关系。 我想要 html 模板列表和表中的一些字段,但我创建的文章不起作用,这里是代码:

模型.py

class article(models.Model):
    name = models.CharField(max_length=100, blank=True, null=True)
    last_name = models.CharField(max_length=254)
    age = models.CharField(max_length=254)

    def __unicode__(self):
        return str(self.id)


class comment(models.Model):
    field_1 = models.CharField(max_length=100, blank=True, null=True)
    field_2 = models.CharField(max_length=254)
    field_3 = models.CharField(max_length=254)
    field_fk= models.ForeignKey('article', blank=True, null=True)

    def __unicode__(self):
        return str(self.id)

视图.py

def index(request):
    apps = article.objects.all()
    comments = comment.objects.all()
    return render(request, 'index.html', {'apps':apps,'comments':comments})

html 模板:

{% for b in apps %}
<p>{{ b.field_1 }}</p>
<p>{{ b.field_2 }}</p>
<p>{{ b.field_3 }}</p>
      {% for c in b.field_fk.comments %}
    <p>{{ c.name }},{{ c.last_name}},{{ c.age}}</p>
          {% endfor %}
{% endfor %}

在我的模板示例中,不显示namelast_nameage为空段落

您不能仅使用.comments访问评论。 使用modelname_set。 在您的情况下,将为comments_set 您的for循环将如下所示:

{% for c in b.field_fk.comment_set.all %}
    <p>{{ c.name }},{{ c.last_name}},{{ c.age}}</p>
{% endfor %}

另外,您没有循环使用正确的模型。 apps设置为Article,但是在您的模板中,您使用的是Comment字段(field_1,field_2 ...)。 第一部分应该是:

{% for article in apps %}
    <p>{{ article.name}}</p>
    <p>{{ article.last_name}}</p>
    <p>{{ article.age}}</p>
...

由于文章是主循环,因此您无需使用外键。 循环应直接使用comment_set:

{% for comment in b.comment_set.all %}
    <p>{{ comment.field_1 }},{{ comment.field_2 }},{{ comment.field_3}}</p>
{% endfor %}

使用此代码

意见.py:

def index(request):
    comments = comment.objects.all()
    return render(request, 'index.html', {'comments':comments})

HTML模板:

{% for b in comments %}
<p>{{ b.field_1 }}</p>
<p>{{ b.field_2 }}</p>
<p>{{ b.field_3 }}</p>
<p>{{ b.field_fk.name }},{{ b.field_fk.last_name}},{{ b.field_fk.age}}</p>
{% endfor %}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM