freemarker定义分页模板

模仿百度分页

1、css样式

/*分页 begin*/
.page_list{width:75%;margin:5% auto;}
.page_list a{ text-decoration: none;font-size:75%;color:#666; display: block;float: left;width:46px;height:46px;line-height:46px;
    margin-right: 10px;text-align: center;background-color: #fff;border:1px solid #dedede;}
.page_list a.top_page,.page_list a.end_page{width:62px;}
.page_list a.page_prev,.page_list a.page_next{width:76px;}
.page_list span.page_ellipsis{display: block;float: left;width:46px;height:46px;margin-right: 10px;background-position:5px -88px;border:none;}
.page_list a:hover ,.page_list a.current{background-color: #dedede;color:#333;}
/*分页 end*/

2、自定义标签

<#-- 参数说明:pageNo当前的页码,totalPage总页数, showPages显示的页码个数,callFunName回调方法名(需在js中自己定义)-->
<#macro page pageNo totalPage showPages callFunName>
	<div class="page_list clearfix">
		<#if pageNo!=1>
        <a href="javascript:${callFunName+'('+1+')'};" class="top_page">首页</a>
        <a href="javascript:${callFunName+'('+(pageNo-1)+')'};" class="page_prev">上一页</a>
        </#if>
        <#if pageNo-showPages/2 gt 0>
        	<#assign start = pageNo-(showPages-1)/2/>
        	<#if showPages gt totalPage>
        		<#assign start = 1/>
        	</#if>
        <#else>
        	<#assign start = 1/>
        </#if>
        <#if totalPage gt showPages>
        	<#assign end = (start+showPages-1)/>
        	<#if end gt totalPage>
        		<#assign start = totalPage-showPages+1/>
        		<#assign end = totalPage/>
        	</#if>
        <#else>
        	<#assign end = totalPage/>
        </#if>
        <#assign pages=start..end/>
        <#list pages as page>
        	<#if page==pageNo>
        		<a href="javascript:${callFunName+'('+page+')'};" class="current">${page}</a>
        	<#else>
        		<a href="javascript:${callFunName+'('+page+')'};">${page}</a>
        	</#if>
        </#list>
		<#if pageNo!=totalPage>
        	<a href="javascript:${callFunName+'('+(pageNo+1)+')'};" class="page_next">下一页</a>
        	<a href="javascript:${callFunName+'('+totalPage+')'};" class="end_page">尾页</a>
        </#if>
    </div>
</#macro>

3、页面中调用

<!-- 导入自定义ftl -->
<#import "/ftl/cast.ftl" as cast/>
<!-- 使用该标签 -->
<@cast.page pageNo=12 totalPage=30 showPages=9 callFunName="alert"/>



FreeMarker是一种模板引擎,可以用于生成各种文本输出,如HTML、XML、JSON等。如果要使用FreeMarker实现分页模板,可以按照以下步骤进行操作: 1. 定义分页数据模型:首先需要定义一个分页数据模型,包含当前页码、每页显示的记录数、总记录数、总页数等信息。可以使用Java对象或Map来表示这个模型。 2. 定义分页模板:使用FreeMarker模板语言定义一个分页模板,其中包含分页数据模型的变量引用、页码链接的生成以及分页导航条的渲染等。 3. 编写Java代码:在Java代码中使用FreeMarker引擎来渲染分页模板,并将分页数据模型传递给模板。 以下是一个简单的示例代码,实现了一个基本的分页模板分页数据模型类: ``` public class PageModel { private int currentPage; // 当前页码 private int pageSize; // 每页显示的记录数 private int totalRecords; // 总记录数 private int totalPages; // 总页数 // 省略getter和setter方法 } ``` FreeMarker模板: ``` <#if pageModel.totalPages gt 1> <div class="pagination"> <ul> <#if pageModel.currentPage gt 1> <li><a href="?page=${pageModel.currentPage-1}">«</a></li> </#if> <#list 1..pageModel.totalPages as page> <#if pageModel.currentPage == page> <li class="active"><a href="#">${page}</a></li> <#else> <li><a href="?page=${page}">${page}</a></li> </#if> </#list> <#if pageModel.currentPage lt pageModel.totalPages> <li><a href="?page=${pageModel.currentPage+1}">»</a></li> </#if> </ul> </div> </#if> ``` Java代码: ``` Configuration cfg = new Configuration(Configuration.VERSION_2_3_28); cfg.setClassForTemplateLoading(getClass(), "/"); Template template = cfg.getTemplate("pagination.ftl"); PageModel pageModel = new PageModel(); pageModel.setCurrentPage(1); pageModel.setPageSize(10); pageModel.setTotalRecords(100); pageModel.setTotalPages(10); Map<String, Object> dataModel = new HashMap<>(); dataModel.put("pageModel", pageModel); Writer out = new StringWriter(); template.process(dataModel, out); System.out.println(out.toString()); ``` 在以上代码中,我们使用了Configuration类来配置FreeMarker引擎,将分页模板文件的目录设置为当前类所在的目录。然后使用Template类加载模板文件,将分页数据模型放入Map中,最后调用process方法渲染模板并输出结果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值