Django Class Based ListView с двумя отфильтрованными индивидуальными списками - PullRequest
0 голосов
/ 01 июня 2018

Привет! Я пытаюсь создать страницу, которая использует модель Элемент с полем модели с именем data_type с выбором целочисленного значения 1 или 2. В настоящее время у меня есть ListViewстраница, и я пытаюсь создать два списка, один, который показывает элементы с data_type = 1, а другой, который показывает data_type = 2.

1 представляет модели, а 2 представляет сценарии, если это поможет?

Вот мои views.py

class ItemListView(generic.ListView):


    context_object_name = 'model_list'
    queryset = Item.objects.filter(data_type='1')

    context_object_name = 'script_list'
    queryset = Item.objects.filter(data_type='2')

    template_name = 'item_list.html',

Item_list.html

<h3 class="text-muted text-center mt-4">Models</h3>
<hr>
<div class="container">
  <div class="row mt-4">
  {% if model_list %}
    {% for item in model_list %}
  <div class="col-md-3">
    <div class="card card-primary card-effects p-2 mb-3 mt-4">
      <a href="{% url 'portal:item_detail' item.pk %}" class="card-full-link">
      <img class="card-img" src="{{ item.image.url }}" alt="Generic placeholder image" width="225" height="185">
      <div class="card-body">
        <p class="text-muted"> {{ item.get_data_type_display }}</p>
        <h4 class="text-left"> {{ item.name }}<span class="text-blue">Ξ{{ item.price }}</span></h4>
      </div>
      </a>
      <!-- <p><a class="btn btn-success" href="#" role="button">Learn more &raquo;</a></p> !-->
    </div>
  </div>
          {% endfor %}
    {% else %}
      <p>There are no items in the database.</p>
    {% endif %}


  </div>
</div>

<h3 class="text-muted text-center mt-4">Scripts </h3>
<hr>
<div class="container">
  <div class="row mt-4">
  {% if script_list %}
    {% for item in script_list %}
  <div class="col-md-3">
    <div class="card card-primary card-effects p-2 mb-3 mt-4">
      <a href="{% url 'portal:item_detail' item.pk %}" class="card-full-link">
      <img class="card-img" src="{{ item.image.url }}" alt="Generic placeholder image" width="225" height="185">
      <div class="card-body">
        <p class="text-muted"> {{ item.get_data_type_display }}</p>
        <h4 class="text-center"> {{ item.name }}<span class="text-blue">Ξ{{ item.price }}</span></h4>
      </div>
      </a>
      <!-- <p><a class="btn btn-success" href="#" role="button">Learn more &raquo;</a></p> !-->
    </div>
  </div>
          {% endfor %}
    {% else %}
      <p>There are no items in the database.</p>
    {% endif %}


  </div>
</div>

Надеюсь, views.py даст вам представление о том, что я пытаюсь сделать.Кажется, что у меня не может быть двух context_object_name и querysets.Если я удалю нижнее context_object_name и queryset, то будет загружен model_list.

Я получил идею набора запросов context_object_name из django docs https://docs.djangoproject.com/en/2.0/topics/class-based-views/generic-display/

1 Ответ

0 голосов
/ 01 июня 2018

Вы можете переопределить get_context_data метод:

class ItemListView(generic.ListView):

    context_object_name = 'model_list'
    queryset = Item.objects.filter(data_type='1')

    template_name = 'item_list.html'

    def get_context_data(self, **kwargs):
        context = super(ItemListView, self).get_context_data(**kwargs)
        context['script_list'] = Item.objects.filter(data_type='2')
        return context  
...