Я использовал django_filters
и вот его код:
from .models import Product
import django_filters
class ProductFilter(django_filters.FilterSet):
product_name = django_filters.CharFilter(lookup_expr='icontains', label='Product Name')
product_price = django_filters.NumberFilter()
product_price__gt = django_filters.NumberFilter(field_name='product_price', lookup_expr='gt', label='Min Price')
product_price__lt = django_filters.NumberFilter(field_name='product_price', lookup_expr='lt', label='Max price')
hotel_location = django_filters.CharFilter(lookup_expr='icontains', label='hotel location')
product_category = django_filters.CharFilter(lookup_expr='icontains', label='product category')
class Meta:
model = Product
fields = ['product_name', 'product_price', 'vendor_name', 'hotel_location', 'product_category']
Функция просмотра содержит следующий код для отображения в шаблонах
def searchTable(request):
product_list = Product.objects.all()
product_filter = ProductFilter(request.GET, queryset=product_list)
return render(request, 'searchTable.html', {'filter': product_filter})
И HTML-код для этого:
<form method="get">
.......
</form>
<table class="table table-hover table-striped table-bordered table-dark" id="myTable">
<thead style="background-color: #3e4e6f; color: white">
<tr>
<th>Image</th>
<th>Product Name</th>
<th>Price</th>
<th>Vendor</th>
</tr>
</thead>
<tbody >
{% for lap in filter.qs|slice:":100" %}
<tr>
<td class="col-sm-3">
<div>
<div class="product-image-wrapper">
<div class="single-products">
<div class="productinfo text-center">
<img src="{{ lap.product_image }}" alt=""/>
</div>
</div>
</div>
</div>
</td>
<td class="col-sm-5">
<h5><a href="{{ lap.product_url }}">{{ lap.product_name }}</a></h5>
<br>
<a href="{{ lap.product_url }}" class="btn btn-secondary" role="button" aria-pressed="true"
style="background-color: #3e4e6f; color: white">See Details</a>
</td>
<td class="col-sm-2">{{ lap.product_price }} ৳</td>
<td class="col-sm-2">{{ lap.vendor_name }}</td>
</tr>
{% empty %}
<tr>
<td colspan="5">No Result Found</td>
</tr>
{% endfor %}
</tbody>
</table>
Теперь мой вопрос, скажем, у меня есть разные категории в product_category
. Как я могу отобразить продукты из какой-либо конкретной категории? Например, product_category="laptop"
.