Flask快速實現(xiàn)分頁效果示例
先上整體效果圖:

然后是分頁圖詳情:



與本例相關(guān)的路由和模板包括:
路由:views.py
@app.route('/blog/list/<int:page>', methods=['GET'])
@login_required
def blog_list(page=None):
...模板:blog_list.html和pages.html
blog_list.html作為博客頁面,pages.html模板為分頁頁面,呈現(xiàn)時會在blog_list.html中導(dǎo)入pages.html的內(nèi)容。
{%import 'pages.html' as pg%}
{{pg.my_paginage(pagination,'art_list')}}首先從路由開始:
路由的設(shè)計思路是根據(jù)查詢的頁碼作為參數(shù),利用FlaskSQLAlchemy的Model進(jìn)行查詢并對查詢結(jié)果進(jìn)行分頁處理。
@app.route('/blog/list/<int:page>', methods=['GET'])
@login_required
def blog_list(page=None):
#每個人只能看自己發(fā)表的blog
if not page:
page = 1
from models import Blog
from models import User
user_id = User.query.filter_by(username=session['user']).first().id
#paginate方法返回一個sqlalchemy.Pagination類型對象
blogs = Blog.query.filter_by(user_id=user_id).order_by(Blog.addtime.desc()).paginate(page=page,per_page=3)
category=[(1, '情感'), (2, '星座'), (3, '愛情')]
return render_template('blog_list.html', title='博客列表',session=session,blogs=blogs.items,category=category,pagination=blogs)分析一下上述代碼:
1. @app.route裝飾器定義了路由
2. @login_required是自定義裝飾器,用來限定只有登錄用戶才可以瀏覽博客列表,未登錄用戶會進(jìn)入登錄頁面
3. 作為Model的Blog中有一個外鍵屬性user_id引用著用戶表,用來記錄博客的作者信息
4. blogs是一個FlaskSQLAlchemy中的Pagination類型對象。一個Query對象調(diào)用paginate方法就獲得了Pagination對象。paginate方法傳入了兩個參數(shù),一個是當(dāng)前頁,另一個是每一頁最多顯示多少博客。paginate的返回值為代表當(dāng)前頁的Pagination對象。一個Paginationi對象的常用屬性有:
- items 當(dāng)前頁面中的所有記錄(比如當(dāng)前頁上有5條記錄,items就是以列表形式組織這5個記錄)
- query 當(dāng)前頁的query對象(通過query對象調(diào)用paginate方法獲得的Pagination對象)
- page 當(dāng)前頁碼(比如當(dāng)前頁是第5頁,返回5)
- prev_num 上一頁頁碼
- next_num 下一頁頁碼
- has_next 是否有下一頁 True/False
- has_prev 是否有上一頁 True/False
- pages 查詢得到的總頁數(shù) per_page 每頁顯示的記錄條數(shù)
- total 總的記錄條數(shù)
常用方法有:
- prev() 上一頁的分頁對象Pagination
- next() 下一頁的分頁對象Pagination
- iter_pages(left_edge=2,left_current=2,right_current=5,right_edge=2)
- iter_pages 用來獲得針對當(dāng)前頁的應(yīng)顯示的分頁頁碼列表。
- 假設(shè)當(dāng)前共有100頁,當(dāng)前頁為50頁,按照默認(rèn)的參數(shù)設(shè)置調(diào)用iter_pages獲得的列表為:
- [1,2,None,48,49,50,51,52,53,54,55,None,99,100]
5. 渲染blog_list.html模板時,傳入渲染時需要的若干參數(shù),比較重要的是傳入blogs參數(shù)用來讓模板顯示查詢出來的應(yīng)該在本頁面中顯示的博客信息,另外是傳入pagination參數(shù),利用傳入的Pagination對象的相關(guān)屬性方法動態(tài)生成分頁的相關(guān)內(nèi)容。
看一下pages.html模板的內(nèi)容:
{%macro my_paginate(pagination,url)%}
<nav>
<ul class="pagination">
{%if pagination.has_prev%}
<li class="page-item active"><a class="page-link" href="{{url_for(url,page=pagination.page-1)}}" rel="external nofollow" >上一頁</a></li>
{%else%}
<li class="page-item disabled"><a class="page-link" href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" >上一頁</a></li>
{%endif%}
{%for page in pagination.iter_pages(1,1,3,1)%}
{%if page%}
<li class="page-item {%if page==pagination.page%}active{%endif%}"><a class="page-link" href="{{url_for(url,page=page)}}" rel="external nofollow" >{{page}}</a></li>
{%else%}
<li class="page-item disabled"><a class="page-link" href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" >…</a></li>
{%endif%}
{%endfor%}
{%if pagination.has_next%}
<li class="page-item active"><a class="page-link" href="{{url_for(url,page=pagination.page+1)}}" rel="external nofollow" >下一頁</a></li>
{%else%}
<li class="page-item disabled"><a class="page-link" href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" >下一頁</a></li>
{%endif%}
</ul>
</nav>
{%endmacro%}分析一下上述頁面代碼:、
整體來說就是根據(jù)當(dāng)前對“上一頁”,“頁碼”和“下一頁”進(jìn)行不同的設(shè)置
1. 使用JinJa2的宏,定義my_paginate方法,傳入路徑和pagination對象作為參數(shù)。通過調(diào)用宏的執(zhí)行生成分頁內(nèi)容。
2. 通過設(shè)置class為pagination,可以使用FlaskBootStrap預(yù)置CSS樣式
3. 利用JinJa2的if語句根據(jù)當(dāng)前頁是否還有前一頁使用不同的元素和class。
如果當(dāng)前頁有上一頁,則pagination對象的has_prev為True,此時li標(biāo)簽的class為page-item和active,采用的BootStrap樣式意 為此時上一頁是可點的。點擊后跳轉(zhuǎn)的鏈接會是url_for函數(shù)根據(jù)傳入的路由方法名稱(也就是url參數(shù)值)并添加上page參數(shù),參數(shù)值為當(dāng)前頁碼-1
如果當(dāng)前頁沒有上一頁,則pagination對象的has_prev為False,此時li標(biāo)簽的class為page-item和disable,采用的BootStrap樣 式意為此時上一頁是不可點的。跳轉(zhuǎn)的鏈接會是#
4. 與“上一頁”處理類似的是對“下一頁”的處理。如果當(dāng)前頁有下一頁時設(shè)置樣式和點擊跳轉(zhuǎn)路徑,如果沒有下一頁了,則設(shè)置為 不可點擊并且跳轉(zhuǎn)路徑為#
5. 利用iter_page(1,1,3,1)會獲得基于當(dāng)前頁應(yīng)該顯示的頁碼列表。如上面截圖所示,如果當(dāng)前頁是第4頁,獲得的分頁列表內(nèi)容 就是[1,None,3,4,5,6,None,9],如果當(dāng)前頁是第9頁,獲得的分頁列表內(nèi)容是[1,None,8,9]
6. 利用JinJa2的for語句遍歷列表,如果是頁碼,就根據(jù)頁碼生成a標(biāo)簽中的文字并設(shè)置跳轉(zhuǎn)路徑并添加上page參數(shù)。如果是None,a標(biāo)簽中的文字為實體名表示的省略號,路徑為“#”。額外的,如果遍歷時獲得了當(dāng)前頁碼所對應(yīng)的數(shù)字時,為li標(biāo)簽的class屬性添加上額外的active以獲得額外的樣式。
最后在blog_list.html中要引入pages.html
{%import 'pages.html' as pg%}
{{pg.my_paginate(pagination,'blog_list')}}在blog_list.html中導(dǎo)入pages.html模板并調(diào)用pages.html中定義的my_pagination宏,傳入兩個參數(shù),第一個參數(shù)是pagination對象,這個參數(shù)是從views.py中渲染blog_list.html的時候傳入的,另外一個就是一個字符串'blog_list',它對應(yīng)的是views.py中路由方法的名稱,有了這個名稱在my_paginate中就可以利用url_for函數(shù)進(jìn)行路由方法對應(yīng)路徑的尋找。
到此這篇關(guān)于Flask快速實現(xiàn)分頁效果示例的文章就介紹到這了,更多相關(guān)Flask 分頁內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python深入06——python的內(nèi)存管理詳解
本篇文章主要介紹了python的內(nèi)存管理詳解,語言的內(nèi)存管理是語言設(shè)計的一個重要方面。它是決定語言性能的重要因素。有興趣的同學(xué)可以了解一下。2016-12-12
Python網(wǎng)頁解析利器BeautifulSoup安裝使用介紹
這篇文章主要介紹了Python網(wǎng)頁解析利器BeautifulSoup安裝使用介紹,本文用一個完整示例一步一步安裝了BeautifulSoup的安裝和使用過程,需要的朋友可以參考下2015-03-03
Python實現(xiàn)將doc轉(zhuǎn)化pdf格式文檔的方法
這篇文章主要介紹了Python實現(xiàn)將doc轉(zhuǎn)化pdf格式文檔的方法,結(jié)合實例形式分析了Python實現(xiàn)doc格式文件讀取及轉(zhuǎn)換pdf格式文件的操作技巧,以及php調(diào)用py文件的具體實現(xiàn)方法,需要的朋友可以參考下2018-01-01
使用matplotlib.pyplot繪制多個圖片和圖表實現(xiàn)方式
這篇文章主要介紹了使用matplotlib.pyplot繪制多個圖片和圖表的實現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-08-08
Python中ModuleNotFoundError: No module named&n
本文主要介紹了Python中ModuleNotFoundError: No module named ‘timm’的錯誤解決,錯誤意味著你的Python環(huán)境中沒有安裝名為“timm”的模塊,下面就介紹一下幾種解決方法,感興趣的可以了解一下2025-03-03
人工智能學(xué)習(xí)Pytorch張量數(shù)據(jù)類型示例詳解
這篇文章主要為大家介紹了人工智能學(xué)習(xí)Pytorch張量數(shù)據(jù)類型的示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步2021-11-11

