FreeMarker开发总结

1.FreeMarker的定义

FreeMarker是一个基于java的免费开源的模板引擎,基于文本的模板输出工具,有着丰富的表达式,还可以自定义表达式。Freemarker可以将后端准备好的数据,通过Freemarker表达式在前端页面展示出来。在软件项目中常常用来生成HTML的 Web页面,可以基于模板生成输出文件,导出复杂样式的excel。

2.FreeMarker工作原理图

在这里插入图片描述

3.springboot工程中配置

  1. 添加maven依赖
<!-- freemarker -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-freemarker</artifactId>
</dependency>
  1. 在springboot项目中的yml配置
spring:
  freemarker:
    cache: false
    suffix: .ftl
    template-loader-path: classpath:/templates
    content-type: text/html; charset=utf-8
    settings:
      number_format: 0   # 数字不进行千分位自动转换,比较大的数字会带有逗号,如1,000

4.常用方法

在说方法前,先吐槽一下Freemarker比较恶心的地方,就是空错误,如果你页面表达式是null,就会报错,所以在使用的时候要先进行空判断,有时候页面报错就是因为这个。

1.获取元素值

<#if (msg)!="">
     ${msg}
</#if>

2.获取map中的值

${map["name"]}

3.foreach,循环输出list,先判断是否

 <#if students ?? && students ?size gt 0>
	   <#list students as student>
		    ${student.name}
		    ${student.age}
		    ${student.sex}
	   </#list>
</#if>                        

4.逻辑判断,if…else方法,
字符串类型判断

<#if type == 1>
    type=1                                 
<#elseif type == 2>
    type=2
</#if>

布尔值类型判断

<#if (booleanVal?string('yes', 'no'))=='yes'>
   <span></span>
<#else>
   <span></span>
</#if>

多个值进行if判断

<#if flag=="1">
	<span> 1 </span>
<#elseif flag=="2">
	<span> 2 </span>
<#elseif flag=="3">
	<span> 3 </span>
<#else> 
	<span> 除了1、2、3之外 </span>
</#if>

5.获取session中的值,如后端在session中保存userId,使用Freemarker
在session中保存userId的值

request.getSession().setAttribute("userId",userId);

在页面使用freemarker表达式,为避免userId的值是空就会报错,所以要先判断一下

<#if Session["userId"]?exists> 
	${Session["userId"]} 
</#if>

6.Freemarker格式化时间

// 输出时间格式 2020-05-09 13:59:32

${createTime?string('yyyy-MM-dd hh:mm:ss')}

7.使用include标签,引入其他页面
抽出公共页面代码,取名right.ftl,如下

<div style="height: 80px;position: fixed;width: 350px;text-align: center;background-color: white;">
    <div class="col-md-6">
        <a href="#" style="text-decoration: none;color: #000000;line-height: 80px;font-size: 22px;">
            <span class="glyphicon glyphicon-edit"></span>
            写文章</a>
    </div>
    <div class="col-md-6">
        <a href="#" style="text-decoration: none;color: #000000;line-height: 80px;font-size: 22px;">
            <span class="glyphicon glyphicon-trash"></span>
            草稿箱</a>
    </div>
</div>

在需要引入该代码的页面中,使用include标签

<#include "right.ftl">
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

高并发

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值