RootMay 17, 2018, 11:50 a.m.

Как я использовал FilterView заместо ListView для упрощения фильтрации

Благодаря FilterView можно упростить и уменьшить код для отображения товаров, продуктов и тд. Что позволит уменьшить код в разы! Сначала я использовал ListView и писал много когда для того, чтобы можно было бы отфильтровать по запросам. Пока один из хороших знакомых мне не посоветовал django-filter . Прочитав про него больше я понял что это то что нужно. После, когда я хотел все свои вьюшки использовать как обьект. Это меня немного озадачило, пока знакомый снова меня не выручил подсказкой об использовании FilterView, а теперь более подробней обсудим её:

У нас есть модель Product которая имеет категорию Collection.

class Collection(models.Model):
    name = models.CharField(verbose_name='Коллекция', max_length=150, default=None)
    slug = models.SlugField(verbose_name='ссылка')
    is_active = models.BooleanField(verbose_name='Статус активности', default=True)

    class Meta:
        db_table = 'collection'
        verbose_name = 'Коллекция'
        verbose_name_plural = 'Коллекции'
        ordering = ('name',)

    def __str__(self):
        return self.name

class Product(models.Model):
    name = models.CharField('название товара', max_length=200)
    category = models.ForeignKey(Category, blank=True, null=True, verbose_name='Категория')
    collection = models.ForeignKey(Collection, blank=True, null=True, verbose_name='Коллекция')
    price = models.IntegerField(verbose_name='цена в ₸', default=0)
    discount = models.IntegerField(verbose_name='скидка в %', default=0)
    recommended = models.BooleanField(verbose_name='Рекомендуемый товар', default=False)
    ....

Нам нужно отобразить ее в шаблоне так, что бы можно было фильтровать или сортировать, как мы хотим. Для этого мы создадим filters.py где напишем:

Ничем не отличается от джанго формы 

import django_filters
from .models import Product

CHOICES =[
        ["name", "по алфавиту"],
        ["price", "дешевые сверху"],
        ["-price", "дорогие сверху"]
]


class ProductFilter(django_filters.FilterSet):
    name = django_filters.CharFilter(name='name', lookup_expr='icontains')
    category__slug = django_filters.CharFilter()
    price__gt = django_filters.NumberFilter(name='price', lookup_expr='gt')
    price__lt = django_filters.NumberFilter(name='price', lookup_expr='lt')
    ordering = django_filters.OrderingFilter(choices=CHOICES, required=True, empty_label=None,)

    class Meta:
        model = Product
        exclude = [field.name for field in Product._meta.fields]
        order_by_field = 'name'

Далее создаем вьюшку которая наследуется от FilterView

class CollectionViews(FilterView):
    template_name = 'product/coolections.html'
    model = Product
    paginate_by = 10
    filterset_class = ProductFilter
    context_object_name = 'products'

    def get_queryset(self):
        qs = self.model.objects.prefetch_related('photo_set')
        if self.kwargs.get('collec_slug'):
            qs = qs.filter(collection__slug=self.kwargs['collec_slug'])
        return qs
Если вы пользуетесь bootstrap можно использовать

django-bootstrap3

{% load bootstrap_tags %} {{ form|as_bootstrap }}
We recommend hosting TIMEWEB
We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.

Круто, круто ))

Спасибо за ценный материал для всего сообщества.
Отмечу, что на сегодняшний день уже можно спокойно переходить на django-bootstrap4 .
А также подружить django-bootstrap4 c bootstrap-material-design . Эта связка вполне успешно работает. Нужно лишь править некоторые мелочи.
PK

Информация полезная, но текст очень похоже на машинный перевод.

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

Comments

Only authorized users can post comments.
Please, Log in or Sign up
Timeweb

Let me recommend you the excellent hosting on which EVILEG is located.

For many years, Timeweb has been proving his stability.

For projects on Django I recommend VDS hosting

View Hosting
VS

C++ - Тест 003. Условия и циклы

  • Result:14points,
  • Rating points-10
VS

C++ - Тест 003. Условия и циклы

  • Result:14points,
  • Rating points-10
IP

C ++ - Test 004. Pointers, Arrays and Loops

  • Result:10points,
  • Rating points-10
Last comments
A
  • Andrey
  • April 28, 2021, 1:25 a.m.

Django - Tutorial 036. How to add authentication through social networks. VKontakte

после того как дам разрешение для просмотра моего емайл, вот такая ошибка: AuthForbidden at /social-auth/complete/vk-oauth2/ Your credentials aren't allowed Вот сетингс: SOC…
DV

Qt/C++ - Lesson 051. QMediaPlayer – simple audio player

Добрый вечер. Хотел бы получить консультацию по работе с проектом на Mac OS. Открыл проект в QT и собрал его. Проблема в том, что он не воспроизводит треки и их названия зацикленно мелькают в по…
SS

Как соответствовать новым требованиям Google Play

Добрый день. Спасибо вам огромное за вашу статью! только начинаю изучать QT под Андроид 4 дня потратил на то чтобы подобрать версию QT которая наконец то скомпилирует мне на windo…
YA

PyQt5 - Tutorial 009. Using QThread with MoveToThread

Hello. Let's say I want to send some variables to "run" define. How can we do that? I modified your code, I tried something like below, but the GUI is frozen that way. I could not be able to und…
R

Распознавание изображений на Python с помощью TensorFlow и Keras

почему то вместо 50000 обрабатывает по 782 картинки кажду. эпоху
Now discuss on the forum

Потеря данных в сигнал/слот

вопрос решен
M

Qt/QML/Android(navigation button) - Стандартные клавиши навигации Андроид

Здравствуйте, пытаюсь заставить работать стандартную андроид-клавишу "назад", пытался разными способоами, они приведены в закомментированном коде. В том числе использовал https://evileg.com/ru/f…
M

Как включить OpenGL в Adnroid эмуляторе QtCreator

Здравствуйте, у меня работают виртуальные машины с Android, но только в дефолтной был включен OpenGL. Потом я удалил дефолтную, создал новые, а в них OpenGL отключен. Справа на втором скриншоте …

QScrollArea dynamically add QCheckBoxes

Всё правильно. Это просто спамер, который отправился в вечный бан.

qml зажатая кнопка мыши в одной MouseArea и сигналы мыши из другой MouseArea

добрый, вы не пробовали отслеживать область видимости мышки через: _mouseArea.containsMouse и когда мышка будет в другой зоне видимости обрабатывать ее состояния?
About
Services
© EVILEG 2015-2021
Recommend hosting TIMEWEB