flask中用paginate可實(shí)現(xiàn)數(shù)據(jù)分頁(yè)效果奈籽,首先梳理一下paginate的知識(shí)點(diǎn)悲酷。
1.paginate的用法
paginate(page, per_page, error_out=True)
>>>page 當(dāng)前頁(yè)數(shù)
>>>per_page 每頁(yè)顯示的條數(shù)
>>>error_out 是否打印錯(cuò)誤信息
2.paginate的屬性
a)paginate.page 當(dāng)前頁(yè)數(shù)
b)paginate.pages 總頁(yè)數(shù)
c)paginate.total 數(shù)據(jù)總條數(shù)
d)paginate.has_prev 是否存在上一頁(yè)
返回布爾值
e)paginate.has_next 是否存在下一頁(yè)
返回布爾值
f)paginate.iter_pages() 所有頁(yè)碼
返回列表 如[1, 2, 3, 4]
g)paginate(page, per_page,error_out).items
返回當(dāng)前頁(yè)的所有數(shù)據(jù)
實(shí)例
查詢所有學(xué)生信息凿跳,每頁(yè)顯示2條數(shù)據(jù)类茂,可以通過(guò)頁(yè)碼和上一頁(yè)巨坊、下一頁(yè)跳轉(zhuǎn)頁(yè)面。
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頁(yè)面解析數(shù)據(jù)
{% extends 'base_main.html' %}
{% block title %}
分頁(yè)顯示學(xué)生信息
{% endblock %}
{% block content %}
<h2>學(xué)生信息</h2>
{% for stu in stus %}
學(xué)生編號(hào):{{ stu.s_id }}<br>
學(xué)生姓名:{{ stu.s_name }}<br>
學(xué)生年齡:{{ stu.s_age }}<br>
<br>
{% endfor %}
當(dāng)前頁(yè)數(shù):{{ paginate.page }}
總頁(yè)數(shù):{{ paginate.pages }}
一共有{{ paginate.total }}條數(shù)據(jù)
<br>
{% if paginate.has_prev %}
<a href="/stu/stupage/?page={{ paginate.prev_num }}">上一頁(yè)</a>
{% endif %}
頁(yè)碼:
{% 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 }}">下一頁(yè)</a>
{% endif %}
{% endblock %}
>>>注意頁(yè)面中a鏈接的地址,需要傳入?yún)?shù)
c)訪問(wèn)請(qǐng)求
>>>首次訪問(wèn),每頁(yè)page參數(shù)侄柔,自動(dòng)給page賦值1仲吏,且當(dāng)前頁(yè)數(shù)每頁(yè)上一頁(yè)
>>>點(diǎn)擊下一頁(yè)
>>>當(dāng)跳轉(zhuǎn)到最后一頁(yè)時(shí),不會(huì)顯示下一頁(yè)的鏈接