亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > Java > 正文

Spring Boot實戰之模板引擎

2024-07-14 08:40:43
字體:
來源:轉載
供稿:網友

雖然現在很多開發,都采用了前后端完全分離的模式,即后端只提供數據接口,前端通過AJAX請求獲取數據,完全不需要用的模板引擎。這種方式的優點在于前后端完全分離,并且隨著近幾年前端工程化工具和MVC框架的完善,使得這種模式的維護成本相對來說也更加低一點。但是這種模式不利于SEO,并且在性能上也會稍微差一點,還有一些場景,使用模板引擎會更方便,比如說郵件模板。這篇文章主要討論Spring boot與模板引擎Thymeleaf、Freemaker以及JSP的集成。

一、集成Thymeleaf

第一步:引入jar包(thymeleaf對應的starter):

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

第二步:配置thymeleaf:

spring: thymeleaf:  prefix: classpath:/templates/  check-template-location: true  cache: false  suffix: .html  encoding: UTF-8  content-type: text/html  mode: HTML5

prefix:指定模板所在的目錄

check-tempate-location: 檢查模板路徑是否存在

cache: 是否緩存,開發模式下設置為false,避免改了模板還要重啟服務器,線上設置為true,可以提高性能。

encoding&content-type:這個大家應該比較熟悉了,與Servlet中設置輸出對應屬性效果一致。

mode:這個還是參考官網的說明吧,并且這個是2.X與3.0不同,本文自動引入的包是2.15。

第三步 編寫thymeleaf模板文件:

<!DOCTYPE HTML><html xmlns="http://www.w3.org/1999/xhtml" xmlns:th="http://www.thymeleaf.org"><head>  <meta content="text/html;charset=UTF-8"/></head><body><h6>Thymeleaf 模板引擎</h6><table border="1" bgcolor="#f0ffff">  <thead>  <tr>    <th>序號</th>    <th>標題</th>    <th>摘要</th>    <th>創建時間</th>  </tr>  </thead>  <tbody th:each="article : ${list}">  <tr>    <td th:text="${article.id}"></td>    <td th:text="${article.title}"></td>    <td th:text="${article.summary}"></td>    <td th:text="${article.createTime}"></td>  </tr>  </tbody></table></body></html>

大家可以看到,thymeleaf還是比較簡單的,并且最大的特點就是的標簽是作為HTML元素的屬性存在的,也就是說,該頁面是可以直接通過瀏覽器來預覽的,只是沒有數據而已,這個很方便大家進行調試。

第四步 配置Controller:

@Controller@RequestMapping("/article")public class ArticleController {  @Autowired  private ArticleService articleService;  @RequestMapping("/articleList.html")  public String getArticleList(Model model, String title, @RequestParam(defaultValue = "10") Integer pageSize,                 @RequestParam(defaultValue = "1") Integer pageNum) {    int offset = (pageNum - 1) * pageSize;    List<Article> list = articleService.getArticles(title, 1L, offset, pageSize);    model.addAttribute("list", list);    return "article/articleList";  }}

注意,這里用的注解是@Controller,而不是@RestController,因為@RestController會自動將返回結果轉為字符串。

第五步 查看結果

Spring,Boot,模板引擎

二、Spring boot與Freemarker的集成

1、引入jar包(Freemarker對應的starter)

<dependency>  <groupId>org.springframework.boot</groupId>  <artifactId>spring-boot-starter-freemarker</artifactId></dependency> 

2、配置freemarker:

spring: freemarker:  template-loader-path: classpath:/templates/  suffix: .ftl  content-type: text/html  charset: UTF-8  settings:   number_format: '0.##'

除了settings外,其他的配置選項和thymeleaf類似。settings會對freemarker的某些行為產生影響,如日期格式化,數字格式化等,感興趣的同學可以參考官網提供的說明:https://freemarker.apache.org/docs/api/freemarker/template/Configuration.html#setSetting-java.lang.String-java.lang.String-

3、編寫freemarker模板文件:

<html>  <title>文章列表</title><body><h6>Freemarker 模板引擎</h6>  <table border="1">    <thead>      <tr>        <th>序號</th>        <th>標題</th>        <th>摘要</th>        <th>創建時間</th>      </tr>    </thead>    <#list list as article>      <tr>        <td>${article.id}</td>        <td>${article.title}</td>        <td>${article.summary}</td>        <td>${article.createTime?string('yyyy-MM-dd hh:mm:ss')}</td>      </tr>    </#list>  </table></body></html>

4、編寫Controller:

@Controller@RequestMapping("/article")public class ArticleController {  @Autowired  private ArticleService articleService;   @RequestMapping("/list.html")  public String getArticles(Model model, String title, @RequestParam(defaultValue = "10") Integer pageSize, Integer pageNum) {    if (pageSize == null) {      pageSize = 10;    }    if (pageNum == null) {      pageNum = 1;    }    int offset = (pageNum - 1) * pageSize;    List<Article> list = articleService.getArticles(title, 1L, offset, pageSize);    model.addAttribute("list", list);    return "article/list";  }}

5、訪問頁面:

Spring,Boot,模板引擎

三、Sring boot與JSP集成:

在正式的項目開發中,現在已經極少用jsp模板了,所以Spring boot對jsp的支持也不是很好,因此配置起來比thymeleaf和Freemaker相對來說就更復雜一點。

第一步 引入jar包:

<dependency>  <groupId>javax.servlet</groupId>  <artifactId>jstl</artifactId></dependency><dependency>  <groupId>org.apache.tomcat.embed</groupId>  <artifactId>tomcat-embed-jasper</artifactId></dependency>

第一個jstl的依賴用于支持el表達式,第二個依賴用于支持jsp。注意,如果是在外部的tomcat中運行,需要將scope設置為provide,防止jar包沖突。

第二步 手動創建webapp目錄:

需要手動在main目錄下創建一個webapp的目錄,結構如下:

Spring,Boot,模板引擎

第三步 jsp路勁配置:

在application.yml中添加如下配置:

spring: mvc:  view:   prefix: /WEB-INF/jsp/   suffix: .jsp

了解Spring mvc的應該很熟悉上面的配置。

第四步 編寫jsp頁面:

<%@ page contentType="text/html;charset=UTF-8" language="java" %><%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%><html><head>  <title>Title</title></head><body>  <table border="1">    <c:forEach var="article" items="${list}">      <tr>        <td>${article.id}</td>        <td>${article.title}</td>        <td>${article.summary}</td>        <td>${article.createTime}</td>      </tr>    </c:forEach>  </table></body></html>

第五步 編寫Controller:

@RequestMapping("/listJsp")  public String getArticleListJsp(Model model, String title, @RequestParam(defaultValue = "10") Integer pageSize, Integer pageNum) {    if (pageSize == null) {      pageSize = 10;    }    if (pageNum == null) {      pageNum = 1;    }    int offset = (pageNum - 1) * pageSize;    List<Article> list = articleService.getArticles(title, 1L, offset, pageSize);    model.addAttribute("list", list);    return "articles";  }

第六步 訪問結果頁面:

Spring,Boot,模板引擎

四、總結

總體來講,Spring boot對thymeleaf和Freemaker支持比較友好,配置相對也簡單一點,在實際的開發中,大多也以這兩種模板引擎為主,很少有用jsp的,jsp現在可能更多是在實驗或者學習階段使用。jsp配置比較麻煩一點的事情是不像前兩者,網上的說法基本一致,但是對Jsp的配置有很多種說法,比如說是不是需要將jar包改成war包?jsp的依賴是否需要設置為provide等等,這個主要依賴于你是否最后要將程序部署到外部的tomcat還是直接運行jar?因為本文都是直接在idea下直接運行Application類,所以這些操作就不需要了。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JAVA教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久久久久久久久久成人| 国产精品视频一区国模私拍| 97在线视频免费看| 亚洲成人精品在线| 欧美性色xo影院| 91系列在线播放| 久久99精品视频一区97| 日韩视频在线一区| 欧美黑人狂野猛交老妇| 国产做受高潮69| 亚洲欧美激情视频| 亚洲精品中文字| 欧美精品videofree1080p| 91av在线国产| 国产97免费视| 欧美美女操人视频| 欧美黄网免费在线观看| 在线视频欧美日韩精品| 欧美一区视频在线| 有码中文亚洲精品| 成人激情在线观看| 欧美日韩综合视频网址| 国产91免费观看| 欧美精品电影免费在线观看| 亚洲二区在线播放视频| 成人性生交大片免费观看嘿嘿视频| 性色av一区二区咪爱| 91久久久久久久久久久| 亚洲视频在线看| 亚洲国产欧美一区二区丝袜黑人| 性亚洲最疯狂xxxx高清| 亚洲国产精品久久91精品| 欧美日韩国产91| 国产+人+亚洲| 久久久久久久影院| 久久伊人精品一区二区三区| 亚洲人成电影网站| 久久福利视频导航| 亚洲最大中文字幕| 中文字幕在线观看亚洲| 欧美日韩色婷婷| 美日韩精品视频免费看| 日韩欧美极品在线观看| 中文字幕成人在线| 国产一区二区三区在线| 91免费精品国偷自产在线| 日韩在线欧美在线国产在线| 91影视免费在线观看| 亚洲美女精品久久| 亚洲精品国产免费| 亚洲男女自偷自拍图片另类| 色午夜这里只有精品| 91av视频在线免费观看| 日本一区二三区好的精华液| 国产一区二区三区在线| 久久精品成人一区二区三区| 国产精品青草久久久久福利99| 国产精品永久免费观看| 黑人巨大精品欧美一区二区免费| 欧美一区二区三区免费观看| 欧美国产精品va在线观看| 91精品国产沙发| 亚洲片国产一区一级在线观看| 中文字幕亚洲专区| 成人av在线亚洲| www.欧美三级电影.com| 久久影院中文字幕| 色狠狠av一区二区三区香蕉蜜桃| 日本精品性网站在线观看| 欧美日韩国产一中文字不卡| 亚洲最大成人网色| 精品久久久久久国产91| 国产激情久久久| 国产精品自产拍在线观看| 日韩**中文字幕毛片| xxxx性欧美| 亚洲一区二区三区sesese| 日韩免费视频在线观看| 91九色国产视频| 麻豆国产精品va在线观看不卡| 91成人福利在线| 国语自产在线不卡| 97久久精品视频| 日本一区二区三区四区视频| 2019日本中文字幕| 97超碰国产精品女人人人爽| 日韩在线免费高清视频| 97国产在线视频| 日韩欧美精品网站| 国产精品av在线| 最新日韩中文字幕| 亚洲福利视频免费观看| 97视频国产在线| 色综合久久中文字幕综合网小说| 91av视频在线| 日韩欧美一区二区三区| 久久成人精品视频| 国产精品一二三视频| 日韩精品亚洲视频| 亚洲人成自拍网站| 精品国内自产拍在线观看| 久久精品福利视频| 精品久久久久久久中文字幕| 久久免费国产精品1| 久久精品人人爽| 国产一区二区三区在线观看网站| 岛国视频午夜一区免费在线观看| 欧美激情性做爰免费视频| 国产精品久久久久久久9999| 91av网站在线播放| 日本高清视频精品| 亚洲人成五月天| 国语自产偷拍精品视频偷| 久久久国产一区二区| 久久精品亚洲精品| 国内免费精品永久在线视频| 青青在线视频一区二区三区| 亚洲成人精品久久久| 欧美日韩免费区域视频在线观看| 久久精品视频99| 欧美日韩国产一中文字不卡| 成人激情视频在线观看| 中文字幕亚洲欧美日韩高清| 亚洲国产日韩欧美在线图片| 国产mv免费观看入口亚洲| 97婷婷大伊香蕉精品视频| 亚洲视屏在线播放| 国产精品亚洲第一区| 久久99热这里只有精品国产| 91久久精品久久国产性色也91| 亚洲综合精品伊人久久| 日韩最新在线视频| 久久久久久久久91| 91久久中文字幕| 国产精品第一第二| 136fldh精品导航福利| 国产精品wwwwww| 国产精品免费久久久| 欧美精品久久久久久久久| 久久综合国产精品台湾中文娱乐网| 55夜色66夜色国产精品视频| 91啪国产在线| 欧美激情精品久久久久| 啊v视频在线一区二区三区| 95av在线视频| 国产盗摄xxxx视频xxx69| www.日本久久久久com.| 国产精品高清在线观看| 久久久精品视频在线观看| 亚洲综合在线小说| 中文字幕亚洲无线码a| 亚洲欧美综合另类中字| 午夜精品蜜臀一区二区三区免费| 国产美女久久精品香蕉69| 亚洲性无码av在线| 久久久久久久爱| 日韩av在线影院| 欧美日韩国产第一页| 欧美极品美女视频网站在线观看免费| 日韩精品中文字幕在线播放| 中文字幕在线观看亚洲| 在线成人激情视频| 91亚洲精华国产精华| 日韩h在线观看|