首页 > 解决方案 > 使用 Django 在订单历史记录页面的 ListView 页面中包含 DetailView 上下文

问题描述

嗨,Djangonauts,

我想在订单历史记录页面(ListView)中添加一些订单详细信息(DetailView),请参见下面的图片示例(我在 photoshop 上制作了图片)。我能够获得灰色部分(要显示的订单列表)但我无法获得要在此页面中显示的项目详细信息。如果我单击View Order Detail它会转到详细信息页面,我可以在其中显示所有这些。但我也需要 ListPage 中的一个小摘要,请参见下面的示例

在此处输入图像描述

下面是我的view.py

class OrderHistory(LoginRequiredMixin, ListView):
    model = Order
    template_name = 'order/order_list.html'

    def get_context_data(self, **kwargs):
        context = super(OrderHistory, self).get_context_data()
        context['order_details'] = Order.objects.filter(emailAddress=self.request.user.email)
        context['order_items'] = OrderItem.objects.filter(order=self.kwargs.get("order"))
        return context

我什至试过 # context['order_items'] = OrderItem.objects.filter(order__id=self.kwargs.get("order.id"))

下面是我的models.py

from django.db import models

class Order(models.Model):
    token = models.CharField(max_length=250, blank=True)
    total = models.DecimalField(max_digits=6, decimal_places=2, verbose_name='USD Order Total')
    emailAddress = models.EmailField(max_length=100, blank=True, verbose_name='Email Address')
    created = models.DateTimeField(auto_now_add=True)
    billingName = models.CharField(max_length=350, blank=True)
    billingAddress1 = models.CharField(max_length=350, blank=True)
    billingCity = models.CharField(max_length=100, blank=True)
    billingZipcode = models.CharField(max_length=10, blank=True)
    billingCountry = models.CharField(max_length=50, blank=True)


class OrderItem(models.Model):
    product = models.ForeignKey(Product, on_delete=models.CASCADE)
    quantity = models.IntegerField()
    price = models.DecimalField(max_digits=5, decimal_places=2, verbose_name='USD Price')
    order = models.ForeignKey(Order, on_delete=models.CASCADE)

        def sub_total(self):
        return self.quantity * self.price

我还在下面附上了我的产品模型。以防万一你需要看

class Product(models.Model):
    name = models.CharField(max_length=250)
    slug = models.SlugField(max_length=250)
    description = models.TextField(blank=True)
    price = models.DecimalField(max_digits=10, decimal_places=2)
    image = models.ImageField(upload_to='product', blank=True)
    stock = models.IntegerField(default=True)

以下是我的模板这个问题不需要它。我相信我在 views.py 做错了什么。但我有它以防万一。

    {% extends 'base.html' %}
    {% load staticfiles %}
    {% block body %}
        <div>
            <div class="text-center">
                <br/>
                <h1 class="text-center my_title">Tasting Order Purchase History</h1>
                <br/>
                {% if order_details %}
                    {% for order in order_details %}
                    <div class="row order_detail_div" >
                        <div class="col-md-2">
                            <b>Order Number: 156{{ order.id }}</b><br/>
                            <small><em>Order Date: {{ order.created|date:"M d Y" }}</em></small>
                        </div>
                        <div class="col-md-1"></div>
                        <div class="col-md-3 text-left">
                            <b>Status: Paid</b><br/>
                            <b>Total items in Order: ()</b>
                        </div>
                        <div class="col-md-1"></div>
                        <div class="col-md-3 order_total_text">
                            <b>Order Total: ${{ order.total }}</b>
                        </div>
                        <div class="col-md-2 view_order_details">
                            <b><a href="{% url 'order:order_detail' order.id %}">View Order Details</a></b>
                        </div>
                    </div>
<!--------------------------This is the code for OrderItem that's not working------->
                    {% for item in order_items %}
                    <div class="row order_item_detail_div">
                        <div class="col-md-2">
                            a <!--This a does not show either -->
                            <img src="{{ item.product.image }}" >
                        </div>
                    </div>
                    {% endfor %}
<!--------------------------Code ends here ----------------------------------->

                {% endfor %}

            {% else %}
                <p>
                    You do not have any orders yet.<br/><br/>
                    <a href="{% url 'home' %}" class="btn btn-secondary">Add more recipes</a>
                </p>
            {% endif %}
        </div>
    </div>
    <br/>
        <br/>
    {% endblock %}

关于如何完成这项工作的任何建议

标签: djangopython-3.xdjango-modelsdjango-templatesdjango-views

解决方案


在您的模板中,您尝试显示不存在的图像,因为您的产品字段是 CharField,因此没有与之关联的图像字段。您的 OrderItem 模型上的产品是否应该是产品模型的 ForeignKey?

请注意,您需要在模板中的图像上调用 url() 方法,即 {{ product.image.url }}。在此处查看有关 FileField 的文档: https ://docs.djangoproject.com/en/2.0/ref/models/fields/#filefield

在您的模板中尝试将 item.price 或数量显示为文本字段,以证明您的查询集正在运行。


推荐阅读