flask用paginate实现分页

1.paginate的用法

paginate(page, per_page, error_out=True)
>>>page 当前页数
>>>per_page 每页显示的条数
>>>error_out 是否打印错误信息

2.paginate的属性

a)paginate.page 当前页数
b)paginate.pages 总页数
c)paginate.total 数据总条数
d)paginate.has_prev 是否存在上一页

返回布尔值

e)paginate.has_next 是否存在下一页

返回布尔值

f)paginate.iter_pages() 所有页码

返回列表 如[1, 2, 3, 4]

g)paginate(page, per_page,error_out).items

返回当前页的所有数据


实例

查询所有学生信息,每页显示2条数据,可以通过页码和上一页、下一页跳转页面。

a)视图
@stu.route('/stupage/')
def stu_page():
    page = int(request.args.get('page', 1))
    per_page = int(request.args.get('per_page', 2))
    paginate = Student.query.order_by('-s_id').paginate(page, per_page, error_out=False)
    stus = paginate.items
    return render_template('stupage.html', paginate=paginate, stus=stus)
b)html页面解析数据
{% extends 'base_main.html' %}
{% block title %}
    分页显示学生信息
{% endblock %}
{% block content %}
    <h2>学生信息</h2>
    {% for stu in stus %}
        学生编号:{{ stu.s_id }}<br>
        学生姓名:{{ stu.s_name }}<br>
        学生年龄:{{ stu.s_age }}<br>
        <br>
    {% endfor %}
    当前页数:{{ paginate.page }}
    总页数:{{ paginate.pages }}
    一共有{{ paginate.total }}条数据
    <br>
    {% if paginate.has_prev %}
        <a href="/stu/stupage/?page={{ paginate.prev_num }}">上一页</a>
    {% endif %}
    页码:
    {% for i in paginate.iter_pages() %}
        <a href="/stu/stupage/?page={{ i }}">{{ i }}</a>
    {% endfor %}
    {% if paginate.has_next %}
        <a href="/stu/stupage/?page={{ paginate.next_num }}">下一页</a>
    {% endif %}
{% endblock %}

>>>注意页面中a链接的地址,需要传入参数


在这里插入图片描述

c)访问请求

>>>首次访问,每页page参数,自动给page赋值1,且当前页数每页上一页


在这里插入图片描述

>>>点击下一页


在这里插入图片描述

>>>当跳转到最后一页时,不会显示下一页的链接


在这里插入图片描述

本文转载 https://www.jianshu.com/p/a68d4e6a20d1
  • 2
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值