Django 搜索后无法分页问题的解决办法

搜索与分页的问题

当我在执行完搜索之后,然后到搜索结果的下一页的时候,会出现搜索的结果消失,只在地址栏中留下了

127.0.0.1:8000/search/?page=1

搜索的结果全部消失

排查问题

  1. 首先我在Django的编辑器中的运行栏中发现了以下错误
UnorderedObjectListWarning: Pagination may yield inconsistent results with an unordered object_list: <class 'article.models.Article'> QuerySet.
  pages = Paginator(lists, 10)

经过搜索是由于: 所得的数据是无效的,故而分页出现错误。

修改方法,在获得的数据之后对所得的数据进行排序

lists = Article.objects.filter(
        Q(title__icontains=word) | Q(context__icontains=word)).order_by('-created_time')
  1. 经过上述方法后发现还是不行,每次传递的参数都是为page,没有其他的数值,故而需要将参数进行传递,以防止参数出现问题。
    故而我在使用javaScript中获得浏览器的地址的参数后加入
 <div class="panginator">
<nav aria-label="Page navigation">
    <ul class="pagination pagination-lg">
        {% if lists.has_previous %}
        <li>
            <a href="?page={{ lists.previous_page_number }}" aria-label="Previous">
                <span aria-hidden="true">&laquo;</span>
            </a>
        </li>
        {% else %}
        <li>
            <a href="?page={{ lists.number }}" aria-label="Previous">
                <span aria-hidden="true">&laquo;</span>
            </a>
        </li>
        {% endif %}

        {% for page in pages.page_range %}
        <li {% if page == lists.number %} class="active" {% endif %}><a
                href="?page={{ page }}">{{ page }}</a></li>
        {% endfor%}

        {% if lists.has_next %}
        <li>
            <a href="?page={{ lists.next_page_number }}" aria-label="Next">
                <span aria-hidden="true">&raquo;</span>
            </a>
        </li>
        {% else %}
        <li>
            <a href="?page={{ lists.number}}" aria-label="Next">
                <span aria-hidden="true">&raquo;</span>
            </a>
        </li>
        {% endif %}
    </ul>

    <script>
        $(document).ready(function(){
            var urls = window.location.href;
            var params = urls.split('?');
            var param_list = params[1].split('&');
            var url='';
            for(var i=0; i<param_list.length; i++){
                if(param_list[i].indexOf('page') == 0)
                {
                    continue;
                }else{
                    url+= '&'+param_list[i];
                }
            }   

            console.log(param_list);
            console.log('url=',url);

            var pages = document.querySelectorAll(".pagination.pagination-lg a");
            for(var i=0; i<pages.length; i++){
                pages[i].href += url;
                console.log(pages[i].href)
            }
        });
    </script>
</div>

在上面的JavaScript中,首先获取到网站地址中的参数,然后通过javascript将参数传入到<a>中的href参数中,解决上述问题。

更多的内容可以到刘龙韬的博客中查看相关的内容

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值