Django
分页
- 分页是指在 web 页面有大量数据需要显示时,当一页的内容太多不利于阅读和不利于数据提取的情况 下,可以分为多页进行显示。 Django
- 提供了一些类来帮助你管理分页的数据 — 也就是说,数据被分在不同页面中,并带有 “ 上一页 / 下 一页 ” 链接。 这些类位于
- django/core/paginator.py 中。
Paginator 对象
对象构造方法
Paginator(object_list, per_page)
参数:
1. object_list 对象列表
2. per_page 每页数据个数
返回值:
1.分页对象
from django.core.paginator import Paginator
# paginator 对象分页 生成paginator对象
notes = a_user.note_set.all() # 获取当前用户所有笔记
paginator = Paginator(notes, 5)
return render(request, 'note/list_note2.html',
locals())
Paginator 属性
//count :对象总数
//num_pages :页面总数
//page_range :从 1 开始的 range 对象 , 用于记录当前面码数
//per_page 每页个数
Paginator 方法
Paginator.page(number)
参数 number 为页码信息 ( 从 1 开始 )
返回当前 number 页对应的页信息
如果提供的页码不存在,抛出 InvalidPage 异常
Paginator 异常 exception
InvalidPage :当向 page() 传入一个无效的页码时抛出
PageNotAnInteger :当向 page() 传入一个不是整数的值时抛出
EmptyPage :当向 page() 提供一个有效值,但是那个页面上没有任何对象时抛出
page 对象
创建对象 Paginator 对象的 page() 方法返回 Page 对象,不需要手动构造
Page 对象属性
- object_list :当前页上所有对象的列表
- number :当前页的序号,从 1 开始
- paginator :当前 page 对象相关的 Paginator 对象
Page 对象方法
- has_next() :如果有下一页返回 True
- has_previous() :如果有上一页返回 True
- has_other_pages() :如果有上一页或下一页返回 True
- next_page_number() :返回下一页的页码,如果下一页不存在,抛出 InvalidPage 异常
- previous_page_number() :返回上一页的页码,如果上一页不存在,抛出 InvalidPage 异常
- len() :返回当前页面对象的个数
说明 :
Page 对象是可迭代对象 , 可以用 for 语句来 访问当前页面中的每个对象
django示例
正在更新中