返回顶部
首页 > 资讯 > 后端开发 > Python >基于SSM 集成 Freemarker模板引擎的方法
  • 712
分享到

基于SSM 集成 Freemarker模板引擎的方法

2024-04-02 19:04:59 712人浏览 安东尼

Python 官方文档:入门教程 => 点击学习

摘要

FreeMarker简介 FreeMarker是一个用Java语言编写的模板引擎,它基于模板来生成文本输出。FreeMarker与WEB容器无关,即在Web运行时,它并不知道Serv

FreeMarker简介

FreeMarker是一个用Java语言编写的模板引擎,它基于模板来生成文本输出。FreeMarker与WEB容器无关,即在Web运行时,它并不知道Servlet或Http。它不仅可以用作表现层的实现技术,而且还可以用于生成XML,jsP或Java 文等。
可以彻底的分离表现层和业务逻辑。
曾经在使用JSP 开发过程中发现在页面中大量的存在业务逻辑的代码,使得页面内容凌乱,在后期大量的修改维护过程中就变得非常困难

FreeMarker的原理就是:模板+数据模型=输出,模板只负责数据在页面中的表现,不涉及任何的逻辑代码,而所有的逻辑都是由数据模型来处理的。用户最终看到的输出是模板和数据模型合并后创建的。

背景

在前后端分离的大趋势下,项目开发过程中,应尽量减少前端和后台的依赖和耦合,前端和后台尽可能采用 ajax 进行交互;但是全站 ajax,不利于网站 SEO,所以引入模板引擎,尽量减少前端对后端的依赖;SSM 架构下一般采用 Freemarker,Spring Boot 架构下一般推荐采用 Thymeleaf 模板引擎;

SSM 集成 Freemarker

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模板引擎的文章就介绍到这了,更多相关SSM 集成 Freemarker模板引擎内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: 基于SSM 集成 Freemarker模板引擎的方法

本文链接: https://lsjlt.com/news/163176.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作