我有两个Django模型:
class Product(models.Model):
name = models.CharField(max_length=80, null=True)
is_active = models.BooleanField(default=False, null=False)
class Image(models.Model):
url = models.CharField(max_length=255, unique=True, null=False)
product = models.ForeignKey('Product', related_name='images')
我有一套特定的产品。每个产品都有多个图像。初始调用类似于:
product_list = product_list.filter(is_active=True).prefetch_related('images')
然后,product_list将根据应用的过滤器进行削减。
当我尝试在显示层(模板)中使用product_list时,我会迭代产品列表。我可以访问所有产品的字段,除了其图片。
{{product.images.0.id}} ==>空
{{product.images}} ==>返回Image.None
通过调试器运行代码,我可以看到正在执行的Image SQL查询,只是没有数据传递给模板。肯定有数据,因为我可以验证通过我的SQL客户端运行它的查询。有人知道为什么会这样吗?如何访问给定产品的图像?
答案 0 :(得分:3)
我解决了我的问题。必须访问预取数据,如:product.images.all.0.id