zoukankan      html  css  js  c++  java
  • Flask用paginate实现数据分页(一)

    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)视图
    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,且当前页数每页上一页

     >>>点击下一页 
     

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

     
     
  • 相关阅读:
    什么是.NET Core以及.NET Core能做什么 菜鸟飞不动
    SQL数据库连接字符串的几种写法整理
    高并发
    前端 防抖&节流,你学到未啊?
    Promise实现一个函数,通过fetch请求一个接口'/api/getdata'(可能成功,也可能失败),超过3秒钟请求未返回则认为超时
    手写实现deepClone方法
    手写Promise.retry方法;实现次数内重试请求
    element-ui的table表格通过子表数据,进行展示左侧展开箭头
    页面导出为PDF格式
    js自定义数字跳动效果computeNumber
  • 原文地址:https://www.cnblogs.com/hzjdpawn/p/12628807.html
Copyright © 2011-2022 走看看