FreeMarker页面引擎
什么是Freemarker?
FreeMarker 是一款免费的模板引擎:即一种基于模板和数据,用来生成输出文本(HTML 网页,电子邮件,配置文件,源代码等)的通用工具.FreeMarker比JSP渲染性能更好,不跟web环境耦合,模板文件写不了java代码,责任更分离。FreeMarker解析优先于JS
FreeMarker原理
模板+数据=输出。模板只负责数据在页面中的表现,不涉及逻辑代码。逻辑由数据模型处理
使用Freemarker添加依赖
<!-- FreeMarker -->
<dependency>
<groupId>org.freemarker</groupId>
<artifactId>freemarker</artifactId>
<version>2.3.30</version>
</dependency>
Freemarker是一个模板引擎,能够用来生成各种文件
空值处理
FreeMarker 中的变量必须要赋值,如果不赋值,那么就会抛出异常.可以使用 **!**来指定默认值,例如:
${name!"这是默认值"}
${} 不能直接获取集合/数组/date类型的数据
Freemarker常用指令
一般以#开头
- include指令
当前模板引入另一个模板文件
<#include "/common/link.ftl" >
- assign 指令
创建变量赋值
<#assign name="小罗"/>
使用${} 获取该变量值
${name}
- list指令
用于循环遍历
<#list pageInfo.list as department>
<tr>
<td>${department.id}</td>
<td>${department.name}</td>
<td>${department.sn}</td>
<td>${department_index}</td> //索引
<td>
</tr>
<#/list>
- if指令
条件判断 condition:将被计算成布尔值的表达式
<#if condition>
<#elseif condition2> //可选
<#else>
</#if> //一定要if结尾
前端 twbs-pagination 分页插件
twbs-pagination 是一个简单的自适应 Bootstarp 样式的分页插件,用于前端绘制分页相关的样式效果。网址:https://esimakin.github.io/twbs-pagination/
例子:
<script>
//分页
$(function(){
$("#pagination").twbsPagination({
totalPages: ${pageInfo.pages} || 1,
startPage: ${pageInfo.pageNum} || 1,
visiblePages:5,
first:"首页",
prev:"上页",
next:"下页",
last:"尾页",
initiateStartPageClick:false,
onPageClick:function(event,page){
$("#currentPage").val(page);
$("#searchForm").submit();
}
});
})
</script>
后端 PageHelper 分页插件
Pagehelper属于MyBatis的一个分页插件,需要添加依赖
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper</artifactId>
<version>5.1.2</version>
</dependency>
Pagehelper属于后端的分页插件,能够帮我们节省代码去计算,还有改sql,它自己就会帮我们去计算,执行
- 需要修改配置文件applicationContext.xml,在sqlSessionFactory下,添加属性
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<!-- 注意其他配置 -->
<property name="plugins">
<array>
<bean class="com.github.pagehelper.PageInterceptor">
<property name="properties">
<!--使用下面的方式配置参数,一行配置一个,下面配的是合理化分页 -->
<value>
pageSizeZero=true
reasonable=true
</value>
</property>
</bean>
</array>
</property>
</bean>
- 使用Pagehelper中提供的 PageInfo 类进行封装,还是要传入当前页和每页条数,以部门为例
- 类QueryObject
//封装分页查询需要的参数
@Setter
@Getter
public class QueryObject {
private int currentPage=1; //当前页
private int PageSize=5; //每页条数}
- 部门接口IDepartmentService
PageInfo<Department> query(QueryObject qo);
- 实现类DepartmentServiceImpl
@Override
public PageInfo<Department> query(QueryObject qo) {
//告诉插件我们查询第几页,每页多少条
PageHelper.startPage(qo.getCurrentPage(),qo.getPageSize());
//查询当前页数据
List<Department> departments = departmentMapper.selectForList(qo);
return new PageInfo<>(departments);
}
- 部门控制器
//处理分页查询页面请求
@RequestMapping("/list")
public String list(QueryObject qo, Model model){
PageInfo<Department> pageInfo = departmentService.query(qo);
model.addAttribute("pageInfo",pageInfo);
return "department/list";
}
- 对应前端页面参数,进行传入