" />

亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Spring Data + Thymeleaf 3 + Bootstrap 4 實現(xiàn)分頁器實例代碼

 更新時間:2017年05月20日 08:38:51   作者:waylau  
本篇文章主要介紹了Spring Data + Thymeleaf 3 + Bootstrap 4 實現(xiàn)分頁器實例代碼,非常具有實用價值,需要的朋友可以參考下

實際上分頁器或者分頁組件在現(xiàn)實中都有廣泛著的應用,照理來說老衛(wèi)沒有必要單獨撰文來提這茬。事實是,我近期剛好在寫一門關于Spring Data、Thymeleaf 3、Bootstrap 4 的應用課程,所以用了Bootstrap 4的樣式,結(jié)果之前很多例如 Bootstrap 3 的表格、分頁器啊之類的插件都不能很好的兼容,百度谷歌無果,而且 Bootstrap 4 還沒有出穩(wěn)定版本,官網(wǎng)的示例也是少的可憐,最終下決心要自己寫個分頁器了,所用到的技術就是 Spring Data、Thymeleaf 3、Bootstrap 4 。

分頁器有哪些需求

中國式報表從來都是最復雜的,隨之衍生而來的分頁器要求也是錯綜復雜。本例為求把分頁器原理告訴給大家,所以,將分頁組件的抽象為以下通用的內(nèi)容:

  1. 顯示頁碼的列表;
  2. 該列表的第一項是“上一頁”,最后一項是“下一頁”;
  3. 當前選中的頁碼要高亮;
  4. 當當前頁的上一頁沒有頁碼可選時,則“上一頁”置為不可點擊的狀態(tài);
  5. 當當前頁的下一頁沒有頁碼可選時,則“下一頁”置為不可點擊的狀態(tài);

我們很容易就能找到一個 Bootstrap 分頁器的設計原型,如下圖:

你可以參考 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(); // 當前頁面索引

構(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ù)列表來遍歷生成頁面元素,比如:

<ul class="pagination" >
 <!-- 上一頁 -->
 <li class="page-item" data-th-classappend="*{first} ? 'disabled' : ''">
 <a href="javascript:void(0);" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" class="page-link" data-th-attr="pageIndex=${page.number} - 1" aria-label="Previous">
  <span aria-hidden="true">?</span>
 </a>
 </li>
 
 <!-- 迭代生成頁碼 -->
 <li class="page-item" data-th-each="i : ${#numbers.sequence(1, page.totalPages)}" 
 data-th-classappend="${(page.number + 1) eq i} ? 'active' : ''" >
 <a class="page-link" data-th-attr="pageIndex=${i} - 1" href="javascript:void(0);" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" >
       <span data-th-text="${i}"></span>
    </a>
 </li>
 
 <!-- 下一頁 -->
 <li class="page-item" data-th-classappend="*{last} ? 'disabled' : ''">
 <a href="javascript:void(0);" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" class="page-link" data-th-attr="pageIndex=${page.number} + 1" aria-label="Next">
  <span aria-hidden="true">?</span>
 </a>
 </li>
</ul>

這個就是簡單版本的分頁器了,可以看到我們的分頁器的“上一頁”和“下一頁”是固定不變的,中間根據(jù) totalPages(總頁數(shù))來動態(tài)生成頁面。同時,我們根據(jù)是否是當前頁(number + 1)來設置樣式是否高亮(active)。“上一頁”和“下一頁”是需要做一下判斷的,若當前頁是第一頁(first)則“上一頁”不能點擊(disabled);如果當前頁是最后一頁(last)則“下一頁”不能點擊(disabled)。

考慮的再多一點

實際上,上面版本可以應付大多數(shù)的應用場景了。但是,可能會有點不完美,比如,我的頁數(shù)很多怎么辦?那么我們的分頁列表可能被拉得很長了,領導們可能會不滿意的!絕對要把這種不滿意的情緒扼殺在搖籃里。

可以看到,假如要做得更加完美,則還需要考慮,當頁數(shù)太多時,應該將某些用省略號。這就涉及到三種情況了:

  1. 當當前頁頁碼接近首頁時,省略號在后部出現(xiàn);
  2. 當當前頁頁碼接最后頁時,省略號在前部出現(xiàn);
  3. 最煩的要屬于,當當前頁在中部時,前部、后部都需要省略號;

帶省略號的分頁器

聰明的工程師們應該馬上行動起來,大致的把算法畫了個圖:

為求簡單,我們預設頁碼的列表最多在 7 頁(你也可以根據(jù)需要來改),也就是說,當 totalPages(總頁數(shù))超過 7時,我們才需要考慮省略號的事情。

  1. “上一頁”和“下一頁”的算法于我們上面的簡單版本類似,這里就不贅述了。
  2. 當前頁面頁碼小于等于4時,省略號在列表后部的倒數(shù)第二個出現(xiàn);
  3. 最后一頁與當前頁面之差小于等于3時,省略號在列表前部的第二個位置出現(xiàn);
  4. 其余情況,則當前頁適中處于中間位置,省略號同時在列表第二個位置及倒數(shù)第二個位置出現(xiàn)。

實現(xiàn)方式如下:

<!-- 處理頁數(shù)大于7 的情況 --> 
<ul class="pagination" data-th-if="${page.totalPages gt 7}" >
 <!-- 上一頁 -->
 <li class="page-item" data-th-classappend="*{first} ? 'disabled' : ''">
 <a href="javascript:void(0);" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" class="page-link" data-th-attr="pageIndex=${page.number} - 1" aria-label="Previous">
  <span aria-hidden="true">?</span>
 </a>
 </li>
 
 <!-- 首頁 -->
 <li class="page-item" data-th-classappend="${(page.number + 1) eq 1} ? 'active' : ''" >
 <a href="javascript:void(0);" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" class="page-link" data-th-attr="pageIndex=0">1</a>
 </li>
 
 
 <!-- 當前頁面小于等于4 -->
 <li class="page-item" data-th-if="${(page.number + 1) le 4}" data-th-each="i : ${#numbers.sequence(2,5)}" 
 data-th-classappend="${(page.number + 1) eq i} ? 'active' : ''" >
 <a class="page-link" href="javascript:void(0);" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" data-th-attr="pageIndex=${i} - 1">
      <span data-th-text="${i}"></span>
    </a>
 </li>

 <li class="page-item disabled" data-th-if="${(page.number + 1) le 4}">
 <a href="javascript:void(0);" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" class="page-link">
  <span aria-hidden="true">...</span>
 </a>
 </li>
 
 <!-- 最后一頁與當前頁面之差,小于等于3 -->
 <li class="page-item disabled" data-th-if="${(page.totalPages-(page.number + 1)) le 3}">
 <a href="javascript:void(0);" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" class="page-link">
  <span aria-hidden="true">...</span>
 </a>
 </li> 
 <li class="page-item" data-th-if="${(page.totalPages-(page.number + 1)) le 3}" data-th-each="i : ${#numbers.sequence(page.totalPages-4, page.totalPages-1)}" 
 data-th-classappend="${(page.number + 1) eq i} ? 'active' : ''" >
 <a class="page-link" href="javascript:void(0);" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" data-th-attr="pageIndex=${i} - 1">
      <span data-th-text="${i}"></span>
    </a>
 </li>
 
 <!-- 最后一頁與當前頁面之差大于3,且 當前頁面大于4-->
 
 <li class="page-item disabled" data-th-if="${((page.number + 1) gt 4) && ((page.totalPages-(page.number + 1)) gt 3 )}">
 <a href="javascript:void(0);" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" class="page-link">
  <span aria-hidden="true">...</span>
 </a>
 </li> 
 <li class="page-item" data-th-if="${((page.number + 1) gt 4) && ((page.totalPages-(page.number + 1)) gt 3 )}" >
  <a href="javascript:void(0);" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" class="page-link" data-th-attr="pageIndex=${page.number}">[[${page.number}]]</a>
 </li>
 <li class="page-item active" data-th-if="${((page.number + 1) gt 4) && ((page.totalPages-(page.number + 1)) gt 3 )}">
 <a href="javascript:void(0);" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" class="page-link" data-th-attr="pageIndex=${page.number} + 1">[[${page.number + 1}]]</a>
 </li>
 <li class="page-item" data-th-if="${((page.number + 1) gt 4) && ((page.totalPages-(page.number + 1)) gt 3 )}">
 <a href="javascript:void(0);" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" class="page-link" data-th-attr="pageIndex=${page.number} + 2">[[${page.number + 2}]]</a>
 </li>
 
 <li class="page-item disabled" data-th-if="${((page.number + 1) gt 4) && ((page.totalPages-(page.number + 1)) gt 3 )}">
 <a href="javascript:void(0);" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" class="page-link">
  <span aria-hidden="true">...</span>
 </a>
 </li>

 <!-- 最后一頁 -->
 <li class="page-item" data-th-classappend="${(page.number + 1) eq page.totalPages} ? 'active' : ''" >
 <a href="javascript:void(0);" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" class="page-link" data-th-attr="pageIndex=${page.totalPages} - 1">[[${page.totalPages}]]</a>
 </li>

 <!-- 下一頁 -->
 <li class="page-item" data-th-classappend="*{last} ? 'disabled' : ''">
 <a href="javascript:void(0);" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" class="page-link" data-th-attr="pageIndex=${page.number} + 1" aria-label="Next">
  <span aria-hidden="true">?</span>
 </a>
 </li>
</ul>

還要再考慮的多一點?

當然,正如我們開篇所講,中國式報表的需求千奇百怪,本文也只是從大部分通用需求出發(fā),給個思路, 不一定能滿足所有人的需求。如果可能的話,再考慮多一點,比如:

  1. 是否可以選擇頁面的最大頁?
  2. 是否可以選擇任意頁面的索引?

等等,看了下表快凌晨1點了。頂不順了,要睡了。各位讀者朋友可以繼續(xù)完善~

最終效果

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • 淺談shiro的SecurityManager類結(jié)構(gòu)

    淺談shiro的SecurityManager類結(jié)構(gòu)

    下面小編就為大家?guī)硪黄獪\談shiro的SecurityManager類結(jié)構(gòu)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-07-07
  • Spring的定時任務@Scheduled源碼詳解

    Spring的定時任務@Scheduled源碼詳解

    這篇文章主要介紹了Spring的定時任務@Scheduled源碼詳解,@Scheduled注解是包org.springframework.scheduling.annotation中的一個注解,主要是用來開啟定時任務,本文提供了部分實現(xiàn)代碼與思路,需要的朋友可以參考下
    2023-09-09
  • Java性能優(yōu)化之關于大對象復用的目標和注意點

    Java性能優(yōu)化之關于大對象復用的目標和注意點

    這篇文章主要介紹了Java性能優(yōu)化之關于大對象復用的目標和注意點,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • SpringBoot3整合SpringDoc OpenAPI生成接口文檔的詳細過程

    SpringBoot3整合SpringDoc OpenAPI生成接口文檔的詳細過程

    SpringDoc OpenAPI 是一個強大的工具,能夠幫助我們輕松生成 OpenAPI 3.0 規(guī)范的文檔,并提供交互式的 Swagger UI 界面,所以本文給大家介紹了SpringBoot3整合SpringDoc OpenAPI生成接口文檔的詳細過程,需要的朋友可以參考下
    2024-07-07
  • 如何使用Spring Security手動驗證用戶的方法示例

    如何使用Spring Security手動驗證用戶的方法示例

    這篇文章主要介紹了如何使用Spring Security手動驗證用戶的方法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-05-05
  • Java?C++題解leetcode764最大加號標志示例

    Java?C++題解leetcode764最大加號標志示例

    這篇文章主要為大家介紹了Java?C++題解leetcode764最大加號標志示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-01-01
  • Java線程之鎖對象Lock-同步問題更完美的處理方式代碼實例

    Java線程之鎖對象Lock-同步問題更完美的處理方式代碼實例

    這篇文章主要介紹了Java線程之鎖對象Lock-同步問題更完美的處理方式代碼實例,還是挺不錯的,這里分享給大家,需要的朋友可以參考。
    2017-11-11
  • SpringBoot中使用Redis?Stream實現(xiàn)消息監(jiān)聽示例

    SpringBoot中使用Redis?Stream實現(xiàn)消息監(jiān)聽示例

    本文主要介紹了SpringBoot中使用Redis?Stream實現(xiàn)消息監(jiān)聽示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-06-06
  • Java實現(xiàn)添加頁碼到PDF文檔

    Java實現(xiàn)添加頁碼到PDF文檔

    頁碼可以清楚了解總頁數(shù)、定位頁數(shù)快速尋找自己所要的文段、打印時不會分不清頭中尾。今天這篇文章就將介紹如何通過Java代碼,以編程的方式將添加頁碼到PDF文檔,需要的可以參考一下
    2023-04-04
  • 使用Netty進行編解碼的操作過程詳解

    使用Netty進行編解碼的操作過程詳解

    這篇文章主要介紹了使用Netty進行編解碼的操作過程詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-07-07

最新評論