python django listview,对POST查询出的结果使用paginator进行分页的解决方案
一、背景
python django listview,对POST查询出的结果使用paginator进行分页时,会出现不按结果集查询的情况,又回到了初始化的结果集的问题。
如只使用GET函数,不存在这个问题。
二、解决方案
运行POST函数后,后来再分页时,实际上运行的是GET函数。所以要在GET函数中进行操作。为了让GET函数操作的是POST后的结果集,要让POST查询出的结果 ,放在扩展上下文的变量中。
class Listview_T(ListView):
template_name = 'technology/listview_T.html'
paginate_by = 10
queryset = models.T.objects.all()
form_class = forms.Tform
initial = {
'name':''
}
extra_context = {
'title':'T',
'pagination_url':'technology:listview_T',
'namne':'a',
'is_paginated':True,
'sqst':queryset
}
# def get_queryset(self):
# return models.T.objects.all()
def get(self,request, *args, **kwargs):
form = self.form_class(initial=self.initial)
# 使用扩展上下文,存储查询出的结果
paginator = Paginator(self.extra_context['sqst'],self.paginate_by)
# 页码,如没有取到,则取1,返回值是数字
page = request.GET.get('page',1)
# 获取页码的对象,里面包含了多个属性
page_obj = paginator.get_page(page)
# 页面属性中的所有记录,用于更新页面
object_list = page_obj.object_list
return render(request,self.template_name,{**locals(),**self.extra_context})
def post(self, request, *args, **kwargs):
# 使用form方便查询
form = self.form_class(request.POST)
if form.is_valid():
# 输出将查询条件
n_str = form.cleaned_data['name']
# 将查询结果放到扩展上下文中
self.extra_context['sqst'] = models.T.objects.filter(Q(t__name__icontains=n_str)|Q(t01__name__icontains=n_str)|Q(name__icontains=n_str))
# 对查询结果进行分布,第1次使用的是POST,以后会调用GET
paginator = Paginator(self.extra_context['sqst'],self.paginate_by)
# 写为1,主要是查询结果自动展示为1
page_obj = paginator.get_page(1)
# 展示出第1个页面,容易出错的地方是不加object_list
object_list = page_obj.object_list
return render(request, self.template_name, {**locals(),**self.extra_context})
return render(request, self.template_name, {'form': form})