这篇文章主要为大家展示了“如何基于SSM集成Freemarker模板引擎”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何基于SSM集成Freemarker模板引擎”这篇文章吧。FreeMark
这篇文章主要为大家展示了“如何基于SSM集成Freemarker模板引擎”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何基于SSM集成Freemarker模板引擎”这篇文章吧。
FreeMarker是一个用Java语言编写的模板引擎,它基于模板来生成文本输出。FreeMarker与WEB容器无关,即在Web运行时,它并不知道Servlet或Http。它不仅可以用作表现层的实现技术,而且还可以用于生成XML,jsP或Java 文等。
可以彻底的分离表现层和业务逻辑。
曾经在使用JSP 开发过程中发现在页面中大量的存在业务逻辑的代码,使得页面内容凌乱,在后期大量的修改维护过程中就变得非常困难
FreeMarker的原理就是:模板+数据模型=输出,模板只负责数据在页面中的表现,不涉及任何的逻辑代码,而所有的逻辑都是由数据模型来处理的。用户最终看到的输出是模板和数据模型合并后创建的。
在前后端分离的大趋势下,项目开发过程中,应尽量减少前端和后台的依赖和耦合,前端和后台尽可能采用 ajax 进行交互;但是全站 ajax,不利于网站 SEO,所以引入模板引擎,尽量减少前端对后端的依赖;SSM 架构下一般采用 Freemarker,Spring Boot 架构下一般推荐采用 Thymeleaf 模板引擎;
引入依赖
<!-- Freemarker 模板引擎 --><dependency> <groupId>org.freemarker</groupId> <artifactId>freemarker</artifactId> <version>2.3.29</version></dependency>
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>
Controller 中调用 调用模板,渲染页面效果;
@RequestMapping(value = "/index", method = RequestMethod.GET)public String index(Model model){ model.addAttribute("fm","2020"); return "index";}
调用模板引擎,跳转到 /WEB-INF/view/index.ftl,传递数据,渲染页面;
定义模板文件 命名为:index.ftl;
<!doctype html><html lang="en"> <head> <meta charset="UTF-8"> <title>首页</title> </head> <body> ${fm} </body></html>
以上是“如何基于SSM集成Freemarker模板引擎”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网精选频道!
--结束END--
本文标题: 如何基于SSM集成Freemarker模板引擎
本文链接: https://lsjlt.com/news/318706.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0