我正在使用django-filter和django rest框架来过滤数据。我的问题是我取回了所有数据,而不是经过过滤的数据。
这是使用过滤器表单呈现页面的视图:
class MyProductsFilterView(LoginRequiredMixin, FilterView):
model = Product
filterset_class = ProductFilter
template_name = "products/my_products.html"
context_object_name = "my_products"
def get_queryset(self):
return Product.objects.filter(user=self.request.user)
def get_context_data(self, **kwargs):
context = super(MyProductsFilterView, self).get_context_data(**kwargs)
context["my_products"] = Product.objects.filter(user=self.request.user).select_related().order_by("-timestamp")
return context
在过滤器表单中单击“应用”按钮时,将调用以下功能:
function applyFilters(event) {
event.preventDefault();
var FiltersForm = $(".filters-form");
$.ajax({
type: 'GET',
url: '/filtered-products/',
data: FiltersForm.serialize(),
success: function(res) {
console.log(res)
},
error: function (res) {
console.log("Error");
}
})
}
过滤器表单已序列化,并发出了获取请求,以使用以下drf类视图获取过滤后的数据:
class FilteredProductsListAPIView(LoginRequiredMixin, ListAPIView):
authentication_classes = (authentication.SessionAuthentication,)
permission_classes = (permissions.IsAuthenticated,)
queryset = Product.objects.all()
serializer_class = ProductSerializer
filter_backends = (filters.DjangoFilterBackend,)
filterset_class = ProductFilter
这是drf类的网址:
url(r"^filtered-products/",
views.FilteredProductsListAPIView.as_view(), name="get-filtered-products")
我得到了所有数据,而不是取回应用过滤器的结果。
答案 0 :(得分:0)
url(r"^filtered-products/",
views.FilteredProductsListAPIView.as_view(), name="get-filtered-products")
在此处调用 FilteredProductsListAPIView ,而您的查询是
queryset = Product.objects.all()
在此视图中,如果要对数据库进行一些过滤,则必须定义get_queryset函数,
def get_queryset(self):
query = SOME_FILTERING
return query