欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Spring Boot和Thymeleaf整合結(jié)合JPA實(shí)現(xiàn)分頁(yè)效果(實(shí)例代碼)

 更新時(shí)間:2021年02月26日 11:33:59   作者:hsm_computer  
這篇文章主要介紹了Spring Boot和Thymeleaf整合結(jié)合JPA實(shí)現(xiàn)分頁(yè)效果,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

在項(xiàng)目里,我需要做一個(gè)Spring Boot結(jié)合Thymeleaf前端模版,結(jié)合JPA實(shí)現(xiàn)分頁(yè)的演示效果。做的時(shí)候發(fā)現(xiàn)有些問(wèn)題,也查了現(xiàn)有網(wǎng)上的不少文檔,發(fā)現(xiàn)能全棧實(shí)現(xiàn)的不多,所以這里我就把我的做法,全部代碼和步驟貼出來(lái)供大家參考。

1 創(chuàng)建項(xiàng)目,用pom.xml引入依賴(lài)

這里將創(chuàng)建名為T(mén)hymeleafWithDB的Maven,在pom.xml里引入如下的依賴(lài)包。

 <dependencies>
	  <dependency>
	   <groupId>org.springframework.boot</groupId>
	   <artifactId>spring-boot-starter-web</artifactId>
		 </dependency>
	  <dependency>
	   <groupId>org.springframework.boot</groupId>   
	<artifactId>spring-boot-starter-thymeleaf</artifactId>
	  </dependency>
	 </dependencies>

而在此項(xiàng)目里,對(duì)應(yīng)的Stock庫(kù)存表如下所示。

字段名

類(lèi)型

說(shuō)明

id

int

主鍵

name

varchar

庫(kù)存貨物名

num

int

庫(kù)存數(shù)量

description

varchar

庫(kù)存貨物的描述

2 編寫(xiě)啟動(dòng)類(lèi)

這個(gè)類(lèi)是中規(guī)中矩的,代碼如下。

package prj;
	import org.springframework.boot.SpringApplication;
	import org.springframework.boot.autoconfigure.SpringBootApplication;
	@SpringBootApplication
	public class SpringBootApp {
	 public static void main(String[] args) {
	  SpringApplication.run(SpringBootApp.class, args);
	 }
	}

3 在控制器類(lèi)里,添加支持分頁(yè)的方法

@RequestMapping("/listByPage")
	 public ModelAndView listByPage(@RequestParam(value = "pageNum", defaultValue = "0") int pageNum,
	@RequestParam(value = "pageSize", defaultValue = "3") int pageSize) {
	  Page<Stock> stocks=stockService.getStockListByPage(pageNum, pageSize);
	  System.out.println("total page:" + stocks.getTotalPages());
	  System.out.println("current Page:" + pageNum);
	  ModelAndView modelAndView = new ModelAndView("listByPage");
	  //傳遞參數(shù)
	  modelAndView.addObject("stocks",stocks);
	  return modelAndView;
	 }

在第2行和第3行定義該方法的參數(shù)時(shí),由于表示當(dāng)前頁(yè)的pageNum和每頁(yè)數(shù)據(jù)個(gè)數(shù)的pageSize參數(shù)都是從url請(qǐng)求里以get參數(shù)的形式得到,所以在之前要加@RequestParam注解,否則的話就無(wú)法從請(qǐng)求里得到這兩個(gè)參數(shù)。

在該方法的第4行里,調(diào)用了stockService對(duì)象的getStockListByPage方法,在傳入分頁(yè)參數(shù)的情況下,得到了當(dāng)前頁(yè)面中的數(shù)據(jù)。同時(shí)為了調(diào)試,還在第5行和第6行里,輸出了當(dāng)前頁(yè)和每頁(yè)個(gè)數(shù)的信息。

在拿到當(dāng)前頁(yè)面的數(shù)據(jù)后,該方法時(shí)通過(guò)第9行的方法,把它加到modelAndView對(duì)象里,并在第10行里,通過(guò)該對(duì)象,向listByPage視圖返回?cái)?shù)據(jù)。

4 編寫(xiě)業(yè)務(wù)邏輯方法

public Page<Stock> getStockListByPage(int pageNum, int pageSize) {
	  Sort sort = new Sort(Sort.Direction.ASC , "ID");
	  Pageable pageable = PageRequest.of(pageNum, pageSize, sort);
	  Page<Stock> stocks = stockRepo.findAll(pageable);
	  return stocks;
	 }

在這個(gè)方法的第2行里,首先通過(guò)Sort對(duì)象,定義了“按ID進(jìn)行升序排列”的排序方式,隨后通過(guò)第3行的PageRequest對(duì)象,定義的分頁(yè)的方式,這里表示起始數(shù)據(jù)的pageNum和每頁(yè)展示數(shù)據(jù)的pageSize值,都是來(lái)自于外部傳入的參數(shù)。

在確定好排序和分頁(yè)的方式后,本方法在第4行里,通過(guò)調(diào)用PagingAndSortingRepository類(lèi)型對(duì)象stockRepo的findAll方法,根據(jù)在參數(shù)pageable里封裝好的分頁(yè)和排序的方式,向MySQL的stock數(shù)據(jù)表里請(qǐng)求數(shù)據(jù),并把得到的數(shù)據(jù)通過(guò)第5行的return語(yǔ)句返回。

5 編寫(xiě)Repo類(lèi)

package prj.repo;
	import org.springframework.data.repository.PagingAndSortingRepository;
	import org.springframework.stereotype.Component;
	import prj.model.Stock;
	@Component
	public interface StockRepo extends PagingAndSortingRepository<Stock, Integer> { }

從第6行的代碼里大家能看到,該Repo類(lèi)實(shí)現(xiàn)( implements)了JPA里包含分頁(yè)和排序功能的PagingAndSortingRepository接口,由于在StockService里調(diào)用的findAll方法已經(jīng)封裝在該JPA接口里了,所以這里在StockRepo類(lèi)里,甚至不需要再寫(xiě)代碼。

6 在application.yml文件里編寫(xiě)JPA和Thymeleaf的配置參數(shù)

spring:
	 jpa:
	 show-sql: true
	 hibernate:
	  dll-auto: validate
	 datasource:
	 url: jdbc:mysql://localhost:3306/stock?serverTimezone=GMT
	 username: root
	 password: 123456
	 driver-class-name: com.mysql.jdbc.Driver
	 thymeleaf:
	 enabled: true
	 content-type: text/html
	 check-template-location: true
	 cache: false
	 prefix: classpath:/templates/
	 suffix: .html

其中在第1行到第10行的代碼里,給出了JPA和MySQL的相關(guān)定義,而在第11行到第17行的代碼里,給出了Thymeleaf模板的參數(shù)。

這里用到的配置參數(shù),其實(shí)在前文里都已經(jīng)說(shuō)明過(guò),不過(guò)請(qǐng)注意第2行和第11行的縮進(jìn),根據(jù)yml配置文件的縮進(jìn)格式,第11行的thymeleaf其實(shí)是和第2行的jpa同級(jí),它們均屬于第1行的spring的子級(jí)配置。

7 添加listByPage.html頁(yè)面,實(shí)現(xiàn)分頁(yè)的效果

根據(jù)配置,該文件是需要放在resources/templates目錄里,具體代碼如下。

<!DOCTYPE html>
	<html lang="en" xmlns:th="http://www.thymeleaf.org">
	<head>
	 <meta charset="UTF-8">
	 <title>庫(kù)存列表</title>
	</head>
	<body>
	<table border="2">
	 <tr>
	  <td>庫(kù)存編號(hào)</td>
	  <td>庫(kù)存貨物</td>
	  <td>數(shù)量</td>
	  <td>描述</td>
	 </tr>
	 <tr th:each="stock : ${stocks}">
	  <td th:text="${stock.ID}"></td>
	  <td th:text="${stock.name}"></td>
	  <td th:text="${stock.num}"></td>	  
		<td th:text="${stock.description}"></td>
	 </tr>

	</table>
	<div>
	 <ul>
	  <li>
	   <a th:href="'/listByPage?pageNum=0'" rel="external nofollow" rel="external nofollow" >首頁(yè)</a>
	  </li>
	  <li th:if="${stocks.hasPrevious()}">
	   <a th:href="'/listByPage?pageNum=' + ${stocks.previousPageable().getPageNumber()}" rel="external nofollow" th:text="上一頁(yè)"></a>
	  </li>
	  <li th:if="${stocks.hasNext()}">
	   <a th:href="'/listByPage?pageNum=' + ${stocks.nextPageable().getPageNumber()}" rel="external nofollow" th:text="下一頁(yè)"></a>
	  </li>
	  <li>
	   <a th:href="'/listByPage?pageNum=' + ${stocks.getTotalPages() - 1}" rel="external nofollow" rel="external nofollow" >尾頁(yè)</a>
	  </li>
	 </ul>
	</div>
	</body>
	</html>

在第22行到第37行的<div>屬性元素里,加入了分頁(yè)的效果,具體說(shuō)明如下。

  • 在第25行的代碼,通過(guò)th:href="'/listByPage?pageNum=0'" rel="external nofollow" rel="external nofollow" 代碼,以u(píng)rl參數(shù)的形式,向控制器類(lèi)的listByPage方法,傳遞了pageNum為0的參數(shù),以展示首頁(yè)數(shù)據(jù)。
  • 在顯示“上一頁(yè)”的效果前,先需要通過(guò)第27行的th:if代碼判斷stocks對(duì)象里是否包含了上一頁(yè)的數(shù)據(jù),如果是,則通過(guò)第28行的代碼展示“上一頁(yè)”鏈接,請(qǐng)注意這里“上一頁(yè)”鏈接所對(duì)應(yīng)的參數(shù),這樣就能通過(guò)該鏈接,得到上一頁(yè)的數(shù)據(jù)。
  • 展示“下一頁(yè)”的方法和展示“上一頁(yè)”的很相似,都是先通過(guò)th:if判斷是否有下一頁(yè)數(shù)據(jù),然后再通過(guò)鏈接得到下一頁(yè)的數(shù)據(jù)。
  • 在第34行的代碼里,通過(guò)th:href="'/listByPage?pageNum=' + ${stocks.getTotalPages() - 1}" rel="external nofollow" rel="external nofollow" 的代碼得到了尾頁(yè)的數(shù)據(jù),請(qǐng)注意這里是用url中pageNum的參數(shù)值,得到尾頁(yè)的數(shù)據(jù)。

8 觀察效果

編寫(xiě)完成后,啟動(dòng)該項(xiàng)目,此時(shí)如果在瀏覽器里輸入http://localhost:8080/listByPage,就能看到如下圖所示的效果。

從中大家能看到,上圖里每頁(yè)的數(shù)據(jù)是3條,而且在數(shù)據(jù)下方展示了對(duì)應(yīng)的分頁(yè)鏈接,由于是第一頁(yè),所以沒(méi)有包含“上一頁(yè)”的鏈接。如果點(diǎn)擊上圖里的“下一頁(yè)”鏈接,就能看到頁(yè)面跳轉(zhuǎn)的效果,如下圖所示。

從中大家不僅能看到頁(yè)面上的數(shù)據(jù)變化,而且還能看到在url里,通過(guò)攜帶pageNum參數(shù)的方式,取到了下一頁(yè)數(shù)據(jù)。并且,由于參數(shù)stocks里已經(jīng)包含了“上一頁(yè)”的數(shù)據(jù),所以還能看到對(duì)應(yīng)的鏈接。同樣地,大家還能自行點(diǎn)擊“首頁(yè)”、“下一頁(yè)”和“尾頁(yè)”等鏈接,以觀察對(duì)應(yīng)的效果。

到此這篇關(guān)于Spring Boot和Thymeleaf整合結(jié)合JPA實(shí)現(xiàn)分頁(yè)效果的文章就介紹到這了,更多相關(guān)Spring Boot和Thymeleaf實(shí)現(xiàn)分頁(yè)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • SpringBoot配置和切換Tomcat流程詳解

    SpringBoot配置和切換Tomcat流程詳解

    這篇文章主要介紹了如何給springboot配置和切換默認(rèn)的Tomcat容器以及相關(guān)的經(jīng)驗(yàn)技巧,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08
  • Java實(shí)現(xiàn)PDF轉(zhuǎn)Word的示例代碼(無(wú)水印無(wú)頁(yè)數(shù)限制)

    Java實(shí)現(xiàn)PDF轉(zhuǎn)Word的示例代碼(無(wú)水印無(wú)頁(yè)數(shù)限制)

    這篇文章主要為大家詳細(xì)介紹了如何利用Java語(yǔ)言實(shí)現(xiàn)PDF轉(zhuǎn)Word文件的效果,并可以無(wú)水印、無(wú)頁(yè)數(shù)限制。文中的示例代碼講解詳細(xì),需要的可以參考一下
    2022-05-05
  • mybatis的selectKey作用詳解

    mybatis的selectKey作用詳解

    這篇文章主要介紹了mybatis的selectKey作用詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。</P><P>
    2022-01-01
  • 淺談java對(duì)象的比較

    淺談java對(duì)象的比較

    這篇文章主要給大家分享java對(duì)象的比較,主要有元素的比較、類(lèi)的比較及比較的方法,想具體了解的小伙伴和小編一起進(jìn)入下面文章內(nèi)容吧
    2021-10-10
  • 基于idea把springboot項(xiàng)目部署到docker

    基于idea把springboot項(xiàng)目部署到docker

    這篇文章主要介紹了基于idea把springboot項(xiàng)目部署到docker,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-01-01
  • SpringBoot綁定配置文件中變量的四種方式總結(jié)

    SpringBoot綁定配置文件中變量的四種方式總結(jié)

    當(dāng)在Spring Boot中需要綁定配置文件中的變量時(shí),可以使用以下注解:@PropertySourc,@Value,@Environment,@ConfigurationProperties,具體實(shí)現(xiàn)代碼示例文中講解的非常詳細(xì),需要的朋友可以參考下
    2023-11-11
  • Java線程變量ThreadLocal詳細(xì)解讀

    Java線程變量ThreadLocal詳細(xì)解讀

    這篇文章主要介紹了Java線程變量ThreadLocal詳細(xì)解讀,多線程訪問(wèn)同一個(gè)變量的時(shí)候,很容易出現(xiàn)問(wèn)題,特別是多線程對(duì)一個(gè)共享變量進(jìn)行寫(xiě)入的時(shí)候,為了線程的安全在進(jìn)行數(shù)據(jù)寫(xiě)入時(shí)候會(huì)進(jìn)行數(shù)據(jù)的同步,需要的朋友可以參考下
    2024-01-01
  • Java實(shí)現(xiàn)將PDF轉(zhuǎn)為PDF/A

    Java實(shí)現(xiàn)將PDF轉(zhuǎn)為PDF/A

    通過(guò)將PDF格式轉(zhuǎn)換為PDF/A格式,可保護(hù)文檔布局、格式、字體、大小等不受更改,從而實(shí)現(xiàn)文檔安全保護(hù)的目的,同時(shí)又能保證文檔可讀、可訪問(wèn)。本文將為大家介紹如何實(shí)現(xiàn)這一轉(zhuǎn)換,需要的可以參考一下
    2022-01-01
  • SpringBoot中如何進(jìn)行統(tǒng)一異常處理

    SpringBoot中如何進(jìn)行統(tǒng)一異常處理

    大家好,本篇文章主要講的是SpringBoot中如何進(jìn)行統(tǒng)一異常處理,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下
    2022-02-02
  • Spring ApplicationListener的使用詳解

    Spring ApplicationListener的使用詳解

    這篇文章主要介紹了Spring ApplicationListener的使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06

最新評(píng)論