實際上分頁器或者分頁組件在現(xiàn)實中都有廣泛著的應(yīng)用,照理來說老衛(wèi)沒有必要單獨撰文來提這茬。事實是,我近期剛好在寫一門關(guān)于Spring Data、Thymeleaf 3、Bootstrap 4 的應(yīng)用課程,所以用了Bootstrap 4的樣式,結(jié)果之前很多例如 Bootstrap 3 的表格、分頁器啊之類的插件都不能很好的兼容,百度谷歌無果,而且 Bootstrap 4 還沒有出穩(wěn)定版本,官網(wǎng)的示例也是少的可憐,最終下決心要自己寫個分頁器了,所用到的技術(shù)就是 Spring Data、Thymeleaf 3、Bootstrap 4 。
創(chuàng)新互聯(lián)建站專注于涿州網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗。 熱誠為您提供涿州營銷型網(wǎng)站建設(shè),涿州網(wǎng)站制作、涿州網(wǎng)頁設(shè)計、涿州網(wǎng)站官網(wǎng)定制、微信平臺小程序開發(fā)服務(wù),打造涿州網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供涿州網(wǎng)站排名全網(wǎng)營銷落地服務(wù)。
分頁器有哪些需求
中國式報表從來都是最復(fù)雜的,隨之衍生而來的分頁器要求也是錯綜復(fù)雜。本例為求把分頁器原理告訴給大家,所以,將分頁組件的抽象為以下通用的內(nèi)容:
我們很容易就能找到一個 Bootstrap 分頁器的設(shè)計原型,如下圖:
你可以參考 Bootstrap 官網(wǎng)的介紹 http://getbootstrap.com/components/#pagination,但建議你不要直接用上面的樣式,因為這個樣式是 Bootstrap 3版本的。 最后,我找到的了Bootstrap 4 里面的樣式,卻不在官網(wǎng) http://www.quackit.com/bootstrap/bootstrap_4/tutorial/bootstrap_pagination.cfm。感謝 books-collection 項目帶給程序員的開源、免費圖書集合!
Spring Data 能做什么
org.springframework.data.domain.Page 是 Spring Data 提供的一個分頁器接口,提供了常用的方法,比如:
List getContent(); // 返回分頁后的數(shù)據(jù)的列表 int getTotalPages(); // 總頁數(shù) long getTotalElements(); // 總數(shù)據(jù)量 boolean isFirst(); // 是否是第一個數(shù)據(jù); boolean isLast(); // 是否是最后一個數(shù)據(jù); int getNumber(); // 當(dāng)前頁面索引
構(gòu)造一個 Page,通常需要傳入一個 org.springframework.data.domain.PageRequest.PageRequest對象,所需參數(shù)為 (int page, int size),其中 page 就是 要請求的頁面的索引,size 是頁面的大?。ㄒ豁撟疃嘤卸嗌賯€數(shù)據(jù))。
Spring Data 可以說提供了我們前端分頁器所需要的所有元素了。
Thymeleaf 牛刀小試
Thymeleaf 作為模版引擎,其好處就是可以綁定數(shù)據(jù)源,并且根據(jù)數(shù)據(jù)源來渲染頁面。最爽的莫過于根據(jù)綁定的數(shù)據(jù)列表來遍歷生成頁面元素,比如:
這個就是簡單版本的分頁器了,可以看到我們的分頁器的“上一頁”和“下一頁”是固定不變的,中間根據(jù) totalPages(總頁數(shù))來動態(tài)生成頁面。同時,我們根據(jù)是否是當(dāng)前頁(number + 1)來設(shè)置樣式是否高亮(active)?!吧弦豁摗焙汀跋乱豁摗笔切枰鲆幌屡袛嗟?,若當(dāng)前頁是第一頁(first)則“上一頁”不能點擊(disabled);如果當(dāng)前頁是最后一頁(last)則“下一頁”不能點擊(disabled)。
考慮的再多一點
實際上,上面版本可以應(yīng)付大多數(shù)的應(yīng)用場景了。但是,可能會有點不完美,比如,我的頁數(shù)很多怎么辦?那么我們的分頁列表可能被拉得很長了,領(lǐng)導(dǎo)們可能會不滿意的!絕對要把這種不滿意的情緒扼殺在搖籃里。
可以看到,假如要做得更加完美,則還需要考慮,當(dāng)頁數(shù)太多時,應(yīng)該將某些用省略號。這就涉及到三種情況了:
帶省略號的分頁器
聰明的工程師們應(yīng)該馬上行動起來,大致的把算法畫了個草圖:
為求簡單,我們預(yù)設(shè)頁碼的列表最多在 7 頁(你也可以根據(jù)需要來改),也就是說,當(dāng) totalPages(總頁數(shù))超過 7時,我們才需要考慮省略號的事情。
實現(xiàn)方式如下:
還要再考慮的多一點?
當(dāng)然,正如我們開篇所講,中國式報表的需求千奇百怪,本文也只是從大部分通用需求出發(fā),給個思路, 不一定能滿足所有人的需求。如果可能的話,再考慮多一點,比如:
等等,尼瑪看來下表快凌晨1點了。頂不順了,要睡了。各位讀者朋友可以繼續(xù)完善~
最終效果
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。