怎么做网站的地图页,网络公司名字免费起名大全,浏览wap网站,石家庄今天最新新闻头条目录 1. freemarker 介绍创建测试工程2.2.2) 配置文件2.2.3) 创建模型类2.2.4) 创建模板2.2.5) 创建controller2.2.6) 创建启动类2.2.7) 测试 2.3) freemarker基础2.3.1) 基础语法种类2.3.2) 集合指令#xff08;List和Map#xff09;2.3.3) if指令2.3.4) 运算符2.3.5) 空值处… 目录 1. freemarker 介绍创建测试工程2.2.2) 配置文件2.2.3) 创建模型类2.2.4) 创建模板2.2.5) 创建controller2.2.6) 创建启动类2.2.7) 测试 2.3) freemarker基础2.3.1) 基础语法种类2.3.2) 集合指令List和Map2.3.3) if指令2.3.4) 运算符2.3.5) 空值处理2.3.6) 内建函数 2.4) 静态化测试2.4.1) 需求分析2.4.2) 静态化测试 1. freemarker 介绍
FreeMarker 是一款 模板引擎 即一种基于模板和要改变的数据 并用来生成输出文本(HTML网页电子邮件配置文件源代码等)的通用工具。 它不是面向最终用户的而是一个Java类库是一款程序员可以嵌入他们所开发产品的组件。
freemarker作为springmvc一种视图格式默认情况下SpringMVC支持freemarker视图格式。
需要创建Spring BootFreemarker工程用于测试模板。
创建测试工程
创建一个freemarker-demo 的测试工程专门用于freemarker的功能测试与模板的测试。
pom.xml如下
?xml version1.0 encodingUTF-8?
project xmlnshttp://maven.apache.org/POM/4.0.0xmlns:xsihttp://www.w3.org/2001/XMLSchema-instancexsi:schemaLocationhttp://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsdparentartifactIdheima-leadnews-test/artifactIdgroupIdcom.heima/groupIdversion1.0-SNAPSHOT/version/parentmodelVersion4.0.0/modelVersionartifactIdfreemarker-demo/artifactIdpropertiesmaven.compiler.source8/maven.compiler.sourcemaven.compiler.target8/maven.compiler.target/propertiesdependenciesdependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-web/artifactId/dependencydependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-freemarker/artifactId/dependencydependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-test/artifactId/dependency!-- lombok --dependencygroupIdorg.projectlombok/groupIdartifactIdlombok/artifactId/dependency!-- apache 对 java io 的封装工具库 --dependencygroupIdorg.apache.commons/groupIdartifactIdcommons-io/artifactIdversion1.3.2/version/dependency/dependencies/project2.2.2) 配置文件
配置application.yml
server:port: 8881 #服务端口
spring:application:name: freemarker-demo #指定服务名freemarker:cache: false #关闭模板缓存方便测试settings:template_update_delay: 0 #检查模板更新延迟时间设置为0表示立即检查如果时间大于0会有缓存不方便进行模板测试suffix: .ftl #指定Freemarker模板文件的后缀名2.2.3) 创建模型类
在freemarker的测试工程下创建模型类型用于测试
package com.heima.freemarker.entity;import lombok.Data;import java.util.Date;Data
public class Student {private String name;//姓名private int age;//年龄private Date birthday;//生日private Float money;//钱包
}2.2.4) 创建模板
在resources下创建templates此目录为freemarker的默认模板存放目录。
在templates下创建模板文件 01-basic.ftl 模板中的插值表达式最终会被freemarker替换成具体的数据。
!DOCTYPE html
html
headmeta charsetutf-8titleHello World!/title
/head
body
b普通文本 String 展示/bbrbr
Hello ${name} br
hr
b对象Student中的数据展示/bbr/
姓名${stu.name}br/
年龄${stu.age}
hr
/body
/html2.2.5) 创建controller
创建Controller类向Map中添加name最后返回模板文件。
package com.xuecheng.test.freemarker.controller;import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.client.RestTemplate;import java.util.Map;Controller
public class HelloController {GetMapping(/basic)public String test(Model model) {//1.纯文本形式的参数model.addAttribute(name, freemarker);//2.实体类相关的参数Student student new Student();student.setName(小明);student.setAge(18);model.addAttribute(stu, student);return 01-basic;}
}01-basic.ftl使用插值表达式填充数据
!DOCTYPE html
html
headmeta charsetutf-8titleHello World!/title
/head
body
b普通文本 String 展示/bbrbr
Hello ${name} br
hr
b对象Student中的数据展示/bbr/
姓名${stu.name}br/
年龄${stu.age}
hr
/body
/html2.2.6) 创建启动类
package com.heima.freemarker;import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;SpringBootApplication
public class FreemarkerDemotApplication {public static void main(String[] args) {SpringApplication.run(FreemarkerDemotApplication.class,args);}
}2.2.7) 测试
请求http://localhost:8881/basic
2.3) freemarker基础
2.3.1) 基础语法种类
1、注释即#-- --介于其之间的内容会被freemarker忽略
#--我是一个freemarker注释--2、插值Interpolation即 ${..} 部分,freemarker会用真实的值代替**${..}**
Hello ${name}3、FTL指令和HTML标记类似名字前加#予以区分Freemarker会解析标签中的表达式或逻辑。
# FTL指令/# 4、文本仅文本信息这些不是freemarker的注释、插值、FTL指令的内容会被freemarker忽略解析直接输出内容。
#--freemarker中的普通文本--
我是一个普通的文本2.3.2) 集合指令List和Map
1、数据模型
在HelloController中新增如下方法
GetMapping(/list)
public String list(Model model){//------------------------------------Student stu1 new Student();stu1.setName(小强);stu1.setAge(18);stu1.setMoney(1000.86f);stu1.setBirthday(new Date());//小红对象模型数据Student stu2 new Student();stu2.setName(小红);stu2.setMoney(200.1f);stu2.setAge(19);//将两个对象模型数据存放到List集合中ListStudent stus new ArrayList();stus.add(stu1);stus.add(stu2);//向model中存放List集合数据model.addAttribute(stus,stus);//------------------------------------//创建Map数据HashMapString,Student stuMap new HashMap();stuMap.put(stu1,stu1);stuMap.put(stu2,stu2);// 3.1 向model中存放Map数据model.addAttribute(stuMap, stuMap);return 02-list;
}2、模板
在templates中新增02-list.ftl文件
!DOCTYPE html
html
headmeta charsetutf-8titleHello World!/title
/head
body#-- list 数据的展示 --
b展示list中的stu数据:/b
br
br
tabletrtd序号/tdtd姓名/tdtd年龄/tdtd钱包/td/tr
/table
hr#-- Map 数据的展示 --
bmap数据的展示/b
br/br/
a href###方式一通过map[keyname].property/abr/
输出stu1的学生信息br/
姓名br/
年龄br/
br/
a href###方式二通过map.keyname.property/abr/
输出stu2的学生信息br/
姓名br/
年龄br/br/
a href###遍历map中两个学生信息/abr/
tabletrtd序号/tdtd姓名/tdtd年龄/tdtd钱包/td /tr
/table
hr/body
/html实例代码
!DOCTYPE html
html
headmeta charsetutf-8titleHello World!/title
/head
body#-- list 数据的展示 --
b展示list中的stu数据:/b
br
br
tabletrtd序号/tdtd姓名/tdtd年龄/tdtd钱包/td/tr#list stus as stutrtd${stu_index1}/tdtd${stu.name}/tdtd${stu.age}/tdtd${stu.money}/td/tr/#list/table
hr#-- Map 数据的展示 --
bmap数据的展示/b
br/br/
a href###方式一通过map[keyname].property/abr/
输出stu1的学生信息br/
姓名${stuMap[stu1].name}br/
年龄${stuMap[stu1].age}br/
br/
a href###方式二通过map.keyname.property/abr/
输出stu2的学生信息br/
姓名${stuMap.stu2.name}br/
年龄${stuMap.stu2.age}br/br/
a href###遍历map中两个学生信息/abr/
tabletrtd序号/tdtd姓名/tdtd年龄/tdtd钱包/td/tr#list stuMap?keys as key trtd${key_index}/tdtd${stuMap[key].name}/tdtd${stuMap[key].age}/tdtd${stuMap[key].money}/td/tr/#list
/table
hr/body
/html上面代码解释
${k_index} index得到循环的下标使用方法是在stu后边加_index它的值是从0开始
2.3.3) if指令
if 指令即判断指令是常用的FTL指令freemarker在解析时遇到if会进行判断条件为真则输出if中间的内容否则跳过内容不再输出。
指令格式
#if /if1、数据模型
使用list指令中测试数据模型判断名称为小红的数据字体显示为红色。
2、模板
tabletrtd姓名/tdtd年龄/tdtd钱包/td/tr#list stus as stutrtd ${stu.name}/tdtd${stu.age}/tdtd ${stu.mondy}/td/tr/#list/table实例代码
tabletrtd姓名/tdtd年龄/tdtd钱包/td/tr#list stus as stu #if stu.name小红tr stylecolor: redtd${stu_index}/tdtd${stu.name}/tdtd${stu.age}/tdtd${stu.money}/td/tr#else trtd${stu_index}/tdtd${stu.name}/tdtd${stu.age}/tdtd${stu.money}/td/tr/#if/#list
/table3、输出
姓名为“小强”则字体颜色显示为红色。
2.3.4) 运算符
1、算数运算符
FreeMarker表达式中完全支持算术运算,FreeMarker支持的算术运算符包括:
加法 减法 -乘法 *除法 /求模 (求余) %
模板代码
b算数运算符/b
br/br/1005 运算 ${100 5 }br/100 - 5 * 5运算${100 - 5 * 5}br/5 / 2运算${5 / 2}br/12 % 10运算${12 % 10}br/
hr除了 运算以外其他的运算只能和 number 数字类型的计算。
2、比较运算符
或者:判断两个值是否相等.!:判断两个值是否不等.或者gt:判断左边值是否大于右边值或者gte:判断左边值是否大于等于右边值或者lt:判断左边值是否小于右边值或者lte:判断左边值是否小于等于右边值 和 模板代码
!DOCTYPE html
html
headmeta charsetutf-8titleHello World!/title
/head
bodyb比较运算符/bbr/br/dldt / 和 ! 比较/dtdd#if xiaoming xiaoming字符串的比较 xiaoming xiaoming/#if/dddd#if 10 ! 100数值的比较 10 ! 100/#if/dd/dldldt其他比较/dtdd#if 10 gt 5 形式一使用特殊字符比较数值 10 gt 5/#if/dddd#-- 日期的比较需要通过?date将属性转为data类型才能进行比较 --#if (date1?date date2?date)形式二使用括号形式比较时间 date1?date date2?date/#if/dd/dlbr/
hr
/body
/htmlController 的 数据模型代码
GetMapping(operation)
public String testOperation(Model model) {//构建 Date 数据Date now new Date();model.addAttribute(date1, now);model.addAttribute(date2, now);return 03-operation;
}比较运算符注意
**和!**可以用于字符串、数值和日期来比较是否相等**和!**两边必须是相同类型的值,否则会产生错误字符串 x 、x 、**X**比较是不等的.因为FreeMarker是精确比较其它的运行符可以作用于数字和日期,但不能作用于字符串使用**gt等字母运算符代替会有更好的效果,因为 FreeMarker会把**解释成FTL标签的结束字符可以使用括号来避免这种情况,如:#if (xy)
3、逻辑运算符
逻辑与:逻辑或:||逻辑非:!
逻辑运算符只能作用于布尔值,否则将产生错误 。
模板代码
b逻辑运算符/bbr/br/#if (10 lt 12 )( 10 gt 5 ) (10 lt 12 )( 10 gt 5 ) 显示为 true/#ifbr/br/#if !falsefalse 取反为true/#if
hr2.3.5) 空值处理
1、判断某变量是否存在使用 “??”
用法为:variable??,如果该变量存在,返回true,否则返回false
例为防止stus为空报错可以加上判断如下 #if stus??#list stus as stu....../#list/#if2、缺失变量默认值使用 “!” 使用!要以指定一个默认值当变量为空时显示默认值 例 ${name!‘’}表示如果name为空显示空字符串。 如果是嵌套对象则建议使用括起来 例 ${(stu.bestFriend.name)!‘’}表示如果stu或bestFriend或name为空默认显示空字符串。
2.3.6) 内建函数
内建函数语法格式 变量?函数名称
1、和到某个集合的大小
${集合名?size}
2、日期格式化
显示年月日: ${today?date} 显示时分秒${today?time} 显示日期时间${today?datetime} 自定义格式化 ${today?string(yyyy年MM月)}
3、内建函数c
model.addAttribute(“point”, 102920122);
point是数字型使用${point}会显示这个数字的值每三位使用逗号分隔。
如果不想显示为每三位分隔的数字可以使用c函数将数字型转成字符串输出
${point?c}
4、将json字符串转成对象
一个例子
其中用到了 assign标签assign的作用是定义一个变量。
#assign text{bank:工商银行,account:10101920201920212} /
#assign datatext?eval /
开户行${data.bank} 账号${data.account}模板代码
!DOCTYPE html
html
headmeta charsetutf-8titleinner Function/title
/head
bodyb获得集合大小/bbr集合大小hrb获得日期/bbr显示年月日: br显示时分秒br显示日期时间br自定义格式化 brhrb内建函数C/bbr没有C函数显示的数值 br有C函数显示的数值hrb声明变量assign/bbrhr
/body
/html内建函数模板页面
!DOCTYPE html
html
headmeta charsetutf-8titleinner Function/title
/head
bodyb获得集合大小/bbr集合大小${stus?size}hrb获得日期/bbr显示年月日: ${today?date} br显示时分秒${today?time}br显示日期时间${today?datetime}br自定义格式化 ${today?string(yyyy年MM月)}brhrb内建函数C/bbr没有C函数显示的数值${point} br有C函数显示的数值${point?c}hrb声明变量assign/bbr#assign text{bank:工商银行,account:10101920201920212} /#assign datatext?eval /开户行${data.bank} 账号${data.account}hr
/body
/html内建函数Controller数据模型
GetMapping(innerFunc)
public String testInnerFunc(Model model) {//1.1 小强对象模型数据Student stu1 new Student();stu1.setName(小强);stu1.setAge(18);stu1.setMoney(1000.86f);stu1.setBirthday(new Date());//1.2 小红对象模型数据Student stu2 new Student();stu2.setName(小红);stu2.setMoney(200.1f);stu2.setAge(19);//1.3 将两个对象模型数据存放到List集合中ListStudent stus new ArrayList();stus.add(stu1);stus.add(stu2);model.addAttribute(stus, stus);// 2.1 添加日期Date date new Date();model.addAttribute(today, date);// 3.1 添加数值model.addAttribute(point, 102920122);return 04-innerFunc;
}2.4) 静态化测试
之前的测试都是SpringMVC将Freemarker作为视图解析器ViewReporter来集成到项目中工作中有的时候需要使用Freemarker原生Api来生成静态内容下面一起来学习下原生Api生成文本文件。
2.4.1) 需求分析
使用freemarker原生Api将页面生成html文件本节测试html文件生成的方法 2.4.2) 静态化测试
根据模板文件生成html文件
①修改application.yml文件添加以下模板存放位置的配置信息完整配置如下
server:port: 8881 #服务端口
spring:application:name: freemarker-demo #指定服务名freemarker:cache: false #关闭模板缓存方便测试settings:template_update_delay: 0 #检查模板更新延迟时间设置为0表示立即检查如果时间大于0会有缓存不方便进行模板测试suffix: .ftl #指定Freemarker模板文件的后缀名template-loader-path: classpath:/templates #模板存放位置②在test下创建测试类
package com.heima.freemarker.test;import com.heima.freemarker.FreemarkerDemoApplication;
import com.heima.freemarker.entity.Student;
import freemarker.template.Configuration;
import freemarker.template.Template;
import freemarker.template.TemplateException;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;import java.io.FileWriter;
import java.io.IOException;
import java.util.*;SpringBootTest(classes FreemarkerDemoApplication.class)
RunWith(SpringRunner.class)
public class FreemarkerTest {Autowiredprivate Configuration configuration;Testpublic void test() throws IOException, TemplateException {//freemarker的模板对象获取模板Template template configuration.getTemplate(02-list.ftl);Map params getData();//合成//第一个参数 数据模型//第二个参数 输出流template.process(params, new FileWriter(d:/list.html));}private Map getData() {MapString, Object map new HashMap();//小强对象模型数据Student stu1 new Student();stu1.setName(小强);stu1.setAge(18);stu1.setMoney(1000.86f);stu1.setBirthday(new Date());//小红对象模型数据Student stu2 new Student();stu2.setName(小红);stu2.setMoney(200.1f);stu2.setAge(19);//将两个对象模型数据存放到List集合中ListStudent stus new ArrayList();stus.add(stu1);stus.add(stu2);//向map中存放List集合数据map.put(stus, stus);//创建Map数据HashMapString, Student stuMap new HashMap();stuMap.put(stu1, stu1);stuMap.put(stu2, stu2);//向map中存放Map数据map.put(stuMap, stuMap);//返回Mapreturn map;}
}