flask 实现分页

对学生表里学生的数据分页:

对应的处理的方法:

@stu.route('/stupage/')
def stu_page():
    # 获取get请求传过来的页数,没有传参数,默认为1
    page = int(request.args.get('page',1))
    # 获取get请求传过来的以多少条数据分页的参数,默认为5
    per_page = int(request.args.get('per_page',5))
    paginate = Student.query.order_by('-s_id').paginate(page, per_page, error_out=False)
    # 获得数据
    stus = paginate.items
    # 返回给前端
    return render_template('stu_page.html', paginate=paginate, stus=stus)   

前端喧染的页面:

{% extends 'base_main.html' %}

{% block title %}
学生分页
{% endblock %}

{% block content %}
    <h2>学生信息</h2>
    {% for stu in stus %}
        学生id:{{ stu.s_id }}
        学生姓名:{{ stu.s_name }}
        学生年龄:{{ stu.s_age }}
        <br>
    {% endfor %}
    <br>
    总页数:{{ paginate.pages }}
    <br>
    总共有{{ paginate.total }}条数据
    <br>
    当前页数:{{ paginate.page }}
    <br>
    # 如果存在上一页
    {% if paginate.has_prev %}
        <a href="/stu/stupage/?page={{ paginate.prev_num }}">上一页:</a>
    {% endif %}

    当前的页数:{{ paginate.page }}
    # 如果存在下一页
    {% if paginate.has_next %}
         <a href="/stu/stupage/?page={{ paginate.next_num }}">下一页:</a></a>
    {% endif %}
    <br>
    页码:{%  for i in  paginate.iter_pages() %}
    <a href="/stu/stupage/?page={{ i }}">{{ i }}</a>
    {% endfor %}


{% endblock %}

猜你喜欢

转载自blog.csdn.net/qq_40861391/article/details/80356222