springboot整合模板引擎之-FreeMarker

目前市面上使用的模板引擎有很多,在Java Web开发领域,常用的模板引擎有jsp, velocity, freemarker, thymeleaf等。接下来我将会整理一下springboot整合模板freemarker和thymeleaf,一起来学习一下吧!学习之前我们先了解一下什么是FreeMarker?用它我们可以实现什么?带着这些疑问,我们就来看一下吧!

1.什么是 FreeMarker?

FreeMarker 是一款 模板引擎: 即一种基于模板和要改变的数据, 并用来生成输出文本(HTML网页,电子邮件,配置文件,源代码等)的通用工具。 它不是面向最终用户的,而是一个Java类库,是一款程序员可以嵌入他们所开发产品的组件。模板编写为FreeMarker Template Language (FTL)。它是简单的,专用的语言, 不是 像PHP那样成熟的编程语言。 那就意味着要准备数据在真实编程语言中来显示,比如数据库查询和业务运算, 之后模板显示已经准备好的数据。在模板中,你可以专注于如何展现数据, 而在模板之外可以专注于要展示什么数据。可概括为一个公式:模板 + 数据模型 = 输出

这种方式通常被称为 MVC (模型 视图 控制器) 模式,对于动态网页来说,是一种特别流行的模式。 它帮助从开发人员(Java 程序员)中分离出网页设计师(HTML设计师)。设计师无需面对模板中的复杂逻辑, 在没有程序员来修改或重新编译代码时,也可以修改页面的样式。而FreeMarker最初的设计,是被用来在MVC模式的Web开发框架中生成HTML页面的,它没有被绑定到 Servlet或HTML或任意Web相关的东西上。它也可以用于非Web应用环境中。

2.如何在springboot中进行使用呢?

2.1引入pom.xml依赖

 <!-- freemarker 模板启动器 -->
 <dependency>
     <groupId>org.springframework.boot</groupId>
     <artifactId>spring-boot-starter-freemarker</artifactId>
 </dependency>

2.2配置文件application.properties中添加配置

#    freemarker静态资源配置

#       设定ftl文件路径
spring.freemarker.tempalte-loader-path=classpath:/templates
#        关闭缓存,及时刷新,上线生产环境需要修改为true
spring.freemarker.cache=false
spring.freemarker.charset=UTF-8
spring.freemarker.check-template-location=true
spring.freemarker.content-type=text/html
spring.freemarker.expose-request-attributes=true
spring.freemarker.expose-session-attributes=true
spring.freemarker.request-context-attribute=request
spring.freemarker.suffix=.ftl

2.3创建Controller测试类(承接上一章的resource配置文件的读取)

package com.bw.auto.modules.web;
import com.bw.auto.resource.Resource;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;

@Controller
public class FreeMarkerTest {
    @Autowired
    private Resource resource;

    @RequestMapping("/freeMarkerTest")
    public String index(Model model){
        model.addAttribute("name",resource.getName());
        model.addAttribute("number",resource.getNumber());
        return "test";
    }

}

2.4前端显示页面创建(flt的创建)

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="utf-8"/>
    <title>FreeMarker</title>
</head>
<body>
<h1>我是FreeMarker测试</h1>
<h1 style="color: red">name:${name}</h1>
<h1 style="color: red">number:${number}</h1>
</body>
</html>

至此整个项目就算完成了,我们看一下项目的工程结构,并且启动一下看看效果!

启动后输入地址:http://localhost:8080/freeMarkerTest

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值