Django-实现分页
视图核心代码
post = Post.objects.all()
p = request.GET.get('p', 1)
paginator = Paginator(post, 4)
try:pages = paginator.page(p)
except PageNotAnInteger:pages = paginator.page(1)
except EmptyPage:pages = paginator.page(paginator.num_pages)
前端核心代码
<nav class&#61;"pagination" style&#61;""><ul>//has_previous()&#xff1a;判断当前页数是否存在上一页{% if pages.has_previous %}//previous_page_number()&#xff1a;如果当前页数存在上一页&#xff0c;就输出上一页的页数&#xff0c;否则抛出EmptyPage异常。<li class&#61;"next-page"><a href&#61;"?p&#61;{{ pages.previous_page_number }}">上一页a>li>{% endif %}<li class&#61;"prev-page">li>//page_range()&#xff1a;将分页后的总页数生成可循环对象。{% for page in pages.paginator.page_range %}{% if pages.number &#61;&#61; page %}<li class&#61;"active"><span>{{ page }}span>li>{% elif pages.number|add:&#39;-1&#39; &#61;&#61; page or pages.number|add:&#39;1&#39; &#61;&#61; page %}<li><a href&#61;"?p&#61;{{ page }}">{{ page }}a>li>{% endif %}{% endfor %}//has_next()&#xff1a;判断当前页数是否存在下一页。{% if pages.has_next %}//next_page_number()&#xff1a;如果当前页数存在下一页&#xff0c;就输出下一页的页数&#xff0c;否则抛出EmptyPage异常。<li class&#61;"next-page"><a href&#61;"?p&#61;{{ pages.next_page_number }}">下一页a>li>{% endif %}ul>nav>
Paginator类一共定义了4个初始化参数和8个类方法&#xff0c;每个初始化参数和类方法的说明如下&#xff1a;
- object_list&#xff1a;必选参数&#xff0c;代表需要进行分页处理的数据&#xff0c;参数值可以为列表、元组或ORM查询的数据对象等。
- per_page&#xff1a;必选参数&#xff0c;设置每一页的数据量&#xff0c;参数值必须为整型。
- orphans&#xff1a;可选参数&#xff0c;如果最后一页的数据量小于或等于参数orphans的值&#xff0c;就将最后一页的数据合并到前一页的数据。比如有23行数据&#xff0c;若参数per_page&#61;10、orphans&#61;5&#xff0c;则数据分页后的总页数为2&#xff0c;第一页显示10行数据&#xff0c;第二页显示13行数据。
- allow_empty_first_page&#xff1a;可选参数&#xff0c;是否允许第一页为空。如果参数值为False并且参数object_list为空列表&#xff0c;就会引发EmptyPage错误。
- validate_number()&#xff1a;验证当前页数是否大于或等于1。
- get_page()&#xff1a;调用validate_number()验证当前页数是否有效&#xff0c;函数返回值调用page()。
- page()&#xff1a;根据当前页数对参数object_list进行切片处理&#xff0c;获取页数所对应的数据信息&#xff0c;函数返回值调用_get_page()。_
- get_page()&#xff1a;调用Page类&#xff0c;并将当前页数和页数所对应的数据信息传递给Page类&#xff0c;创建当前页数的数据对象。
- count()&#xff1a;获取参数object_list的数据长度。
- num_pages()&#xff1a;获取分页后的总页数。
- page_range()&#xff1a;将分页后的总页数生成可循环对象。
- _check_object_list_is_ordered()&#xff1a;如果参数object_list是ORM查询的数据对象&#xff0c;并且该数据对象的数据是无序排列的&#xff0c;就提示警告信息。
从Paginator类定义的get_page()、page()和_get_page()得知&#xff0c;三者之间存在调用关系
Page类的定义过程&#xff0c;它一共定义了3个初始化参数和7个类方法&#xff0c;每个初始化参数和类方法的说明如下&#xff1a;
- object_list&#xff1a;必选参数&#xff0c;代表已切片处理的数据对象。
- number&#xff1a;必选参数&#xff0c;代表用户传递的页数。
- paginator&#xff1a;必选参数&#xff0c;代表Paginator类的实例化对象。
- has_next()&#xff1a;判断当前页数是否存在下一页。
- has_previous()&#xff1a;判断当前页数是否存在上一页。
- has_other_pages()&#xff1a;判断当前页数是否存在上一页或者下一页。
- next_page_number()&#xff1a;如果当前页数存在下一页&#xff0c;就输出下一页的页数&#xff0c;否则抛出EmptyPage异常。
- previous_page_number()&#xff1a;如果当前页数存在上一页&#xff0c;就输出上一页的页数&#xff0c;否则抛出EmptyPage异常。
- start_index()&#xff1a;输出当前页数的第一行数据在整个数据列表的位置&#xff0c;数据位置从1开始计算。
- end_index()&#xff1a;输出当前页数的最后一行数据在整个数据列表的位置&#xff0c;数据位置从1开始计算。