Django prefetch_related输出无

时间:2017-07-22 14:07:18

标签: python django django-1.11

我是Django的新手。我正在做一个简单的商店。 目前我正在处理Order部分。 每个订单里面都有订单商品。每个订单商品都有一些价值和产品ID。

我想在index.html上显示的是订单及其内部的商品。但是order.items始终输出order.OrderItem.None

views.py

class IndexView(generic.ListView):
    template_name = 'order/index.html'
    context_object_name = 'all_orders'

    def get_queryset(self):
        return Order.objects.all().prefetch_related('items')

    def get_context_data(self, **kwargs):
        context = super(IndexView, self).get_context_data(**kwargs)
        return context

views.py

# Create your models here.
class Order(models.Model):
    user = models.ForeignKey(User, related_name='orders')
    created_at = models.DateTimeField(auto_now_add=True, null=True)

class OrderItem(models.Model):
    product = models.ForeignKey(Product)
    order = models.ForeignKey(Order, related_name='items')
    item_name = models.CharField(max_length=255, null=True, blank=True)
    item_price_in_usd = models.DecimalField(max_digits=6, decimal_places=2, null=True, blank=True)

    def __str__(self):
        return self.product.name

的index.html

{% for order in all_orders %}
        <tr>
            <td>{{ order}}</td>
            <td>{{ order.created_at}}</td>
            <td>{{ order.items}}</td>
        </tr>
    {% endfor %}

1 个答案:

答案 0 :(得分:2)

好的,我找到了解决方案。显然你必须添加.all

{% for order in all_orders %}
        <tr>
            <td>{{ order}}</td>
            <td>{{ order.created_at}}</td>
            <td>
                {% for items in order.items.all %}
                    <td>{{ items.item_name}}</td>
                {% endfor %}
            </td>
        </tr>
    {% endfor %}