Отображение объектов по категориям в Django - PullRequest
0 голосов
/ 01 апреля 2020

Я создаю приложение для электронной коммерции, и я хотел бы создать раздел, показывающий некоторые избранные элементы по категориям. Я использую три ползунка, которые отображают эти элементы; Каждый ползунок является избранной категорией, а каждый элемент ползунка - избранным. Проблема в том, что я не могу понять, как назначить элемент на соответствующий слайдер. Например: я хочу присвоить JeansJacket «Одежда и аксессуары» и отобразить его. Я попробовал это:

{% for cat in categories %}
    <h1>{{ cat.cat_name }}</h1>
     <!--(carousel code in between)-->
        <div class="carousel-inner" role="listbox">
        {% for item in featured_items %}
            {% if item.Categoría in cat.cat_name %}
                {{ item }}
            {% endif %}

Это упрощенная версия того, что у меня есть, без остального содержимого. Я просто не могу понять, как перебирать избранные элементы и отображать их в соответствующей категории.

Редактировать: это в models.py:

class Categorías(models.Model):
    cat_name = models.CharField(max_length=30)
    Destacado = models.BooleanField()
    class Meta:
        ordering = ('cat_name',)
        verbose_name = 'Categoría'
        verbose_name_plural = 'Categorías'
    def __str__(self): 
        return self.cat_name

class publicaciones(models.Model):
    Título = models.CharField(max_length=30)
    Descripción = models.TextField(max_length=200)
    Precio = models.FloatField()
    Fotos = models.ImageField()
    Categoría = models.ForeignKey(Categorías, on_delete=models.CASCADE)
    Promocionado = models.BooleanField()
    class Meta:
        verbose_name = 'Publicación'
        verbose_name_plural = 'Publicaciones'
    def __str__(self):
        return self.Título

1 Ответ

1 голос
/ 01 апреля 2020

Вы можете использовать prefetch_related и Prefetch с пользовательским запросом, чтобы получить все связанные статьи для каждой категории.

categories = Categorías.objects.prefetch_related(Prefetch(
    'publicaciones_set',
    queryset=publicaciones.objects.filter(Promocionado=True),
    to_attr='featured_items'
))

Теперь вы можете l oop по каждой категория, а затем l oop за эту предварительную выборку. Вам не нужно создавать отдельный featured_items queryset

for category in categories:
    for featured_item in category.featured_items:
        ...

Вы можете использовать применить этот шаблон к вашему шаблону

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...