如何在listview中对筛选的查询集进行分页

时间:2013-10-24 23:24:48

标签: python django listview pagination

我正在尝试在listview页面上添加搜索栏。它会第一次获取所有帖子项目,如果查询放入搜索框并提交,它将返回一个过滤的查询集。它渲染得很好,但只有分页问题。对于非过滤的查询集,下一页将获得接下来的两个帖子没有任何问题,但对于过滤的查询集,我可以通过查看更少的页面看到查询集正确反映,但下一页获取非过滤的第二页queryset不是筛选的查询集。任何人都可以给我一些指示我在这里做错了什么。感谢

我的模板如下所示:

{% block content %}
  .....
 <form action="" method="get">
            <input type="text" name='q'>
            <input type="submit" value="Search">
     </form>


    {% for post in object_list %}
    ....
    {% endfor %}


    {% if is_paginated %}
            <div class="pagination">
                <span class="page-links">
                    {% if page_obj.has_previous %}
                        <a href="?page={{ page_obj.previous_page_number }}"><<</a>
                    {% endif %}
                    <span class="page-current">
                        Page {{ page_obj.number }} of {{ page_obj.paginator.num_pages }}
                    </span>
                    {% if page_obj.has_next %}
                        <a href="?page={{ page_obj.next_page_number }}">>></a>
                    {% endif %}
                </span>
            </div>
{% endif %}

我有一个如下所示的列表视图。

class Postlist(ListView):
model=post    
paginate_by = 2
query_string = ''

def get_queryset(self):


    if ('q' in self.request.GET) and self.request.GET['q'].strip():
       query_string = self.request.GET['q']
       entry_query = get_query(query_string, ['title', 'body',]) ## call get_query() function
       queryset = post.objects.filter(entry_query).order_by('-created')

    else:
       queryset=post.objects.all().order_by('-created')

    return queryset

def get_context_data(self):
    context = super(ListView, self).get_context_data(**kwargs)
    context['q'] = query_string
    ## do sth here to pre-populate the input text box
    return context

1 个答案:

答案 0 :(得分:0)

让我结束这个。两个选项:使用隐藏字段保存用户搜索词,并使用此选项来筛选每个请求的查询集;或使用会话。这是会话代码示例。我可以想到使用会话缓存的唯一缺点是它将整个查询集缓存在内存中,因此它将为高流量网站终止内存。由于我在个人网站上使用它,它根本不会受到伤害。

查看档案

class Postlist(ListView):
model=post
paginate_by = 2

def get_queryset(self):
    query_string = ''
    if ('search' in self.request.GET) and self.request.GET['search'].strip():
       query_string = self.request.GET['search']
       entry_query = get_query(query_string, ['title', 'body',]) ## call get_query to clean search terms
       queryset = post.objects.filter(entry_query).order_by('-created')
       self.request.session['searchset']=queryset

    else:
       if self.request.session.get('searchset') and ('page' in self.request.GET):
           queryset=self.request.session['searchset']
       else:
           queryset=post.objects.all().order_by('-created')
           if self.request.session.get('searchset'):
             del self.request.session['searchset']
    return queryset

表单文件

from django import forms

类SearchForm(forms.Form):     search = forms.CharField(max_length = 30)