flask中用paginate可实现数据分页效果,首先梳理一下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,且当前页数每页上一页
>>>点击下一页
>>>当跳转到最后一页时,不会显示下一页的链接