前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >FreeMarker的基本语法

FreeMarker的基本语法

作者头像
CBeann
发布2023-12-25 16:43:24
1370
发布2023-12-25 16:43:24
举报
文章被收录于专栏:CBeann的博客CBeann的博客

Freemarker

FreeMarker 是一款 模板引擎: 即一种基于模板和要改变的数据, 并用来生成输出文本(HTML网页,电子邮件,配置文件,源代码等)的通用工具。 它不是面向最终用户的,而是一个Java类库,是一款程序员可以嵌入他们所开发产品的组件。

模板编写为FreeMarker Template Language (FTL)。它是简单的,专用的语言, 不是 像PHP那样成熟的编程语言。 那就意味着要准备数据在真实编程语言中来显示,比如数据库查询和业务运算, 之后模板显示已经准备好的数据。在模板中,你可以专注于如何展现数据, 而在模板之外可以专注于要展示什么数据。

这种方式通常被称为 MVC (模型 视图 控制器) 模式,对于动态网页来说,是一种特别流行的模式。 它帮助从开发人员(Java 程序员)中分离出网页设计师(HTML设计师)。设计师无需面对模板中的复杂逻辑, 在没有程序员来修改或重新编译代码时,也可以修改页面的样式。

而FreeMarker最初的设计,是被用来在MVC模式的Web开发框架中生成HTML页面的,它没有被绑定到 Servlet或HTML或任意Web相关的东西上。它也可以用于非Web应用环境中。

在js中获取后端传来的数据

代码语言:javascript
复制
var error='${error}'

基本语法

int,double,long类似
代码语言:javascript
复制
		int intVar=1;
		map.put("intVar", intVar);
代码语言:javascript
复制
<h5>intVar:${intVar}</h5>
Boolean
代码语言:javascript
复制
                Boolean booleanVar=true;
		map.put("booleanVar", booleanVar);
代码语言:javascript
复制
<h5>booleanVar:${booleanVar}</h5>
null
代码语言:javascript
复制
map.put("nullVar", null);
代码语言:javascript
复制
<h5>nullVar:${nullVar}</h5>
<h5>nullVar:${nullVar!'我是默认值'}</h5>
不存在的变量
代码语言:javascript
复制
<h5>missVar:${abvas}</h5>
遍历List<Student>和if标签
代码语言:javascript
复制
List<Student> listVar=new ArrayList<>();
		for (int i = 0; i < 3; i++) {
			Student stu=new Student(i, "张三"+i, 1);
			listVar.add(stu);
		}
		Student stu=new Student(3, "李四", 2);
		listVar.add(stu);
		Student stu2=new Student(4, "王五", 3);
		listVar.add(stu2);
		map.put("listVar", listVar);
代码语言:javascript
复制
<#list  listVar as item>
 ID:${item.id}----Name:${item.name}----Sex:${item.sex}
 
  <#if item.sex==1>
       女
   <#elseif item.sex==2>
       男
   <#else>
       其他
   </#if>
 
 
 <br/>
</#list>
Map
代码语言:javascript
复制
		Map<String,Object> mapVar=new HashMap<>();
		mapVar.put("张三", "123");
		mapVar.put("李四", "456");
		map.put("mapVar", mapVar);
代码语言:javascript
复制
<#list  mapVar?keys as key>
${key}----${mapVar[key]}<br/>
</#list>
Switch标签
代码语言:javascript
复制
int switchVar=65;
		map.put("switchVar", switchVar);
代码语言:javascript
复制
<#switch switchVar>
<#case 61>61 <#break>
<#case 62>62 <#break>
<#default>63
</#switch>
Date
代码语言:javascript
复制
map.put("dateVar", new Date());
代码语言:javascript
复制
${dateVar?string('yyyy-MM-dd HH:mm:ss')} //日期格式

代码集合

controller
代码语言:javascript
复制
package com.example.demo.handler;

import java.util.ArrayList;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

import com.example.demo.entity.Student;

@Controller
public class HelloHandler {
	
	@RequestMapping("/hello")
	public String hello(Map<String,Object> map){
		System.out.println("init ");
		
		//int
		int intVar=1;
		map.put("intVar", intVar);
		
		//boolean
		Boolean booleanVar=true;
		map.put("booleanVar", booleanVar);
		
		//null就是不存在
		map.put("nullVar", null);
		
		//List and 自定义student
		List<Student> listVar=new ArrayList<>();
		for (int i = 0; i < 3; i++) {
			Student stu=new Student(i, "张三"+i, 1);
			listVar.add(stu);
		}
		Student stu=new Student(3, "李四", 2);
		listVar.add(stu);
		Student stu2=new Student(4, "王五", 3);
		listVar.add(stu2);
		map.put("listVar", listVar);
		
		//map
		Map<String,Object> mapVar=new HashMap<>();
		mapVar.put("张三", "123");
		mapVar.put("李四", "456");
		map.put("mapVar", mapVar);
		
		
		//switch Var
		int switchVar=65;
		map.put("switchVar", switchVar);
		
		//date
		map.put("dateVar", new Date());
		
		
		
		
		return "result";
	}

}
view
代码语言:javascript
复制
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
<h1>Result HTML</h1>
<h5>intVar:${intVar}</h5>
<h5>long,double类似</h5>
<h5>booleanVar:${booleanVar}</h5>
<h5>nullVar:${nullVar}</h5>
<h5>nullVar:${nullVar!'我是默认值'}</h5>
<h5>missVar:${abvas}</h5>
<h5>intVar+1:${intVar+1}</h5>

<h5>listVar(Student)</h5>
<#list  listVar as item>
 ID:${item.id}----Name:${item.name}----Sex:${item.sex}
 
  <#if item.sex==1>
       女
   <#elseif item.sex==2>
       男
   <#else>
       其他
   </#if>
 
 
 <br/>
</#list>
<br/>
<h5>mapVar</h5>
<#list  mapVar?keys as key>
${key}----${mapVar[key]}<br/>
</#list>
<br/>
<h5>Switch</h5>
<#switch switchVar>
<#case 61>61 <#break>
<#case 62>62 <#break>
<#default>63
</#switch>
<br/>

---
${dateVar?string('yyyy-MM-dd HH:mm:ss')} //日期格式

</body>
</html>

项目下载

点击打开链接项目代码

注意:项目是SpringBoot+freemarker,虽然不是SSM或者其它,但是只要你配置好了上面的语句没毛病,老铁

代码语言:javascript
复制
######################################
###freeMarker
######################################
spring.freemarker.allow-request-override=false
spring.freemarker.allow-session-override=false
spring.freemarker.cache=false
spring.freemarker.check-template-location=true
#spring.freemarker.charset=UTF-8 
spring.freemarker.content-type=text/html 
spring.freemarker.enabled=true
spring.freemarker.expose-request-attributes=false 
spring.freemarker.expose-session-attributes=false 
spring.freemarker.expose-spring-macro-helpers=true
spring.freemarker.prefer-file-system-access=true 
#zhi shi zhong dian
spring.freemarker.suffix=.html
spring.freemarker.template-loader-path=classpath:/templates/
spring.freemarker.settings.template_update_delay=5
spring.freemarker.settings.default_encoding=UTF-8
spring.freemarker.settings.classic_compatible=true





######################################
###server
######################################
##server.context-path=/SpringBoot01


######################################
###spring MVC view  spring.mvc.view.prefix=/WEB-INF/jsp/
######################################
#spring.mvc.view.prefix=/WEB-INF/jsp/
#spring.mvc.view.suffix=.jsp


######################################
###other
######################################
#aaa=bbb

######################################
###spring datasource
######################################
#spring.datasource.url=jdbc:mysql://localhost:3306/springboot
#spring.datasource.username=root
#spring.datasource.password=root
#spring.datasource.driver-class-name=com.mysql.jdbc.Driver
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-03-07,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Freemarker
  • 在js中获取后端传来的数据
  • 基本语法
    • int,double,long类似
      • Boolean
        • null
          • 不存在的变量
            • 遍历List<Student>和if标签
              • Map
                • Switch标签
                  • Date
                  • 代码集合
                    • controller
                      • view
                      • 项目下载
                      领券
                      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档