您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“如何基于SSM集成Freemarker模板引擎”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“如何基于SSM集成Freemarker模板引擎”這篇文章吧。
FreeMarker是一個用Java語言編寫的模板引擎,它基于模板來生成文本輸出。FreeMarker與Web容器無關,即在Web運行時,它并不知道Servlet或HTTP。它不僅可以用作表現層的實現技術,而且還可以用于生成XML,JSP或Java 文等。
可以徹底的分離表現層和業務邏輯。
曾經在使用JSP 開發過程中發現在頁面中大量的存在業務邏輯的代碼,使得頁面內容凌亂,在后期大量的修改維護過程中就變得非常困難
FreeMarker的原理就是:模板+數據模型=輸出,模板只負責數據在頁面中的表現,不涉及任何的邏輯代碼,而所有的邏輯都是由數據模型來處理的。用戶最終看到的輸出是模板和數據模型合并后創建的。
在前后端分離的大趨勢下,項目開發過程中,應盡量減少前端和后臺的依賴和耦合,前端和后臺盡可能采用 ajax 進行交互;但是全站 ajax,不利于網站 SEO,所以引入模板引擎,盡量減少前端對后端的依賴;SSM 架構下一般采用 Freemarker,Spring Boot 架構下一般推薦采用 Thymeleaf 模板引擎;
1、引入依賴
<!-- Freemarker 模板引擎 --> <dependency> <groupId>org.freemarker</groupId> <artifactId>freemarker</artifactId> <version>2.3.29</version> </dependency>
2、spring mvc 核心配置文件,spring-mvc.xml,添加相關配置;
<!-- freeMarker 視圖解析器 --> <bean id="viewResolverFtl" class="org.springframework.web.servlet.view.freemarker.FreeMarkerViewResolver"> <property name="viewClass" value="org.springframework.web.servlet.view.freemarker.FreeMarkerView"/> <property name="contentType" value="text/html; charset=utf-8"/> <property name="cache" value="false"/> <property name="suffix" value=".ftl"/> <property name="order" value="0"/> <property name="requestContextAttribute" value="request"/> </bean> <!-- freemarker 核心配置 --> <bean id="freemarkerConfig" class="org.springframework.web.servlet.view.freemarker.FreeMarkerConfigurer"> <!--解析路徑--> <property name="templateLoaderPath" value="/WEB-INF/view/"></property> <!-- 設置 FreeMarker 環境屬性 --> <property name="freemarkerSettings"> <props> <!--刷新模板的周期,單位為秒 --> <prop key="template_update_delay">5</prop> <!--模板的編碼格式 --> <prop key="default_encoding">UTF-8</prop> <!-- 本地化設置 --> <prop key="locale">UTF-8</prop> <prop key="datetime_format">yyyy-MM-dd HH:mm:ss</prop> <prop key="time_format">HH:mm:ss</prop> <prop key="number_format">0.####</prop> <prop key="boolean_format">true,false</prop> <prop key="whitespace_stripping">true</prop> <prop key="tag_syntax">auto_detect</prop> <prop key="url_escaping_charset">UTF-8</prop> </props> </property> </bean>
2、Controller 中調用 調用模板,渲染頁面效果;
@RequestMapping(value = "/index", method = RequestMethod.GET) public String index(Model model){ model.addAttribute("fm","2020"); return "index"; }
調用模板引擎,跳轉到 /WEB-INF/view/index.ftl,傳遞數據,渲染頁面;
3、定義模板文件 命名為:index.ftl;
<!doctype html> <html lang="en"> <head> <meta charset="UTF-8"> <title>首頁</title> </head> <body> ${fm} </body> </html>
以上是“如何基于SSM集成Freemarker模板引擎”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。