vue项目接口域名动态的获取方法
312
2022-09-07
Django之实现分页显示内容
分页
1、作用
数据加载优化
2、前端引入bootstrap样式:
{# 引入bootstrap样式的cdn资源 #}
引入分页器:
3、Paginator
数据分页工具对象创建
Paginator(数据集,每一页数据数)
属性
count:对象总数page_range:页码列表,从1开始num_pages:页面总数
方法
page(整数): 获得一个page对象
常见错误
InvalidPage:page()传递无效页码PageNotAnInteger:page()传递的不是整数Empty:page()传递的值有效,但是没有数据
4、Page
具体的某一页面对象获得,通过Paginator的page()方法获得属性
object_list:当前页面上所有的数据对象number:当前页的页码值paginator: 当前page关联的Paginator对象
方法
has_next():判断是否有下一页has_previous():判断是否有上一页has_other_pages():判断是否有上一页或下一页next_page_number():返回下一页的页码previous_page_number():返回上一页的页码len():返回当前页的数据的个数
# 显示博文列表# pagenum=路由参数=用户想要查看第几页def showBlogs(request, pagenum): # 查询数据库获取所有博文 blogs = Blog.objects.all() # 构建分页器对象,blogs=所有博文,2=每页显示的个数 paginator = Paginator(blogs, 2) # 获取第n页的页面对象 page = paginator.page(pagenum) # Paginator和Page的常用API # page.previous_page_number() # page.next_page_number() # page.has_previous() # page.has_next() # 构造页面渲染的数据 ''' 渲染需要的数据: - 当前页的博文对象列表 - 分页页码范围 - 当前页的页码 ''' data = { # 当前页的博文对象列表 'page': page, # 分页页码范围 'pagerange': paginator.page_range, # 当前页的页码 'currentpage': page.number, } # 将数据丢给页面渲染 return render(request, 'blogs.html', context=data)
后记
关注我,我们一起成长~~
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~