Freemarker自定义的分页指令

分页标签pager.ftl的全部代码:

<#– 自定义的分页指令。
属性说明:
pageNo 当前页号(int类型)
pageSize 每页要显示的记录数(int类型)
toURL 点击分页标签时要跳转到的目标URL(string类型)
recordCount 总记录数(int类型)
使用方式:
<#if recordCount??>
<#import “/pager.ftl” as q>
<@q.pager pageNo=pageNo pageSize=pageSize recordCount=recordCount toURL=”testpager.do”/>
</#if>
–>
<#macro pager pageNo pageSize toURL recordCount>
<#– 定义局部变量pageCount保存总页数 –>
<#assign pageCount=((recordCount + pageSize – 1) / pageSize)?int>
<#if recordCount==0>共0页<#return></#if>

<#– 页号越界处理 –>
<#if (pageNo > pageCount)>
<#assign pageNo=pageCount>
</#if>
<#if (pageNo < 1)>
<#assign pageNo=1>
</#if>
<#– 上一页处理 –>
<#if (pageNo == 1)>
<a class=”disabled threeWord”>上一页</a>
<#else>
<a href=”${toURL}&pageNo=${pageNo – 1}” class=”threeWord”>上一页</a>
</#if>
<#– 如果前面页数过多,显示… –>
<#assign start=1>
<#if (pageNo > 4)>
<#assign start=(pageNo – 1)>
<a href=”${toURL}&pageNo=1″ class=”oneWord”>1</a>
<a href=”${toURL}&pageNo=2″ class=”oneWord”>2</a>&hellip;
</#if>
<#– 显示当前页号和它附近的页号 –>
<#assign end=(pageNo + 1)>
<#if (end > pageCount)>
<#assign end=pageCount>
</#if>
<#list start..end as i>
<#if (pageNo==i)>
<a class=”currentp”>${i}</a>
<#else>
<a href=”${toURL}&pageNo=${i}” class=”oneWord”>${i}</a>
</#if>
</#list>
<#– 如果后面页数过多,显示… –>
<#if (end < pageCount – 2)>
&hellip;
</#if>
<#if (end < pageCount – 1)>
<a href=”${toURL}&pageNo=${pageCount – 1}” class=”oneWord”>${pageCount-1}</a>
</#if>
<#if (end < pageCount)>
<a href=”${toURL}&pageNo=${pageCount}” class=”oneWord”>${pageCount}</a>
</#if>
<#– 下一页处理 –>
<#if (pageNo == pageCount)>
<a class=”disabled threeWord”>下一页</a>
<#else>
<a href=”${toURL}&pageNo=${pageNo + 1}” class=”threeWord”>下一页</a>
<a href=”${toURL}&pageNo=${pageCount}” class=”twoWord”>尾页</a>
</#if>
共<span class=”oneWord”>${pageCount}</span>页,跳到
<input type=”number” name=”gotoPageNo” min=”1″ max = “${pageCount}” maxlength=”4″>&nbsp;页
<button onclick=”javascript:gotopage()”>确定</button>
<script language=”javascript”>
function gotopage(){
var gotoPageNo = $(“input[name=’gotoPageNo’]”).val();
if(” != gotoPageNo){
if(${pageCount} < gotoPageNo){
gotoPageNo = ${pageCount};
}
if(1 > gotoPageNo){
gotoPageNo = 1;
}
location.href = “${toURL}&pageNo=” + gotoPageNo;
}else{
alert(“请输入页码!”);
$(“input[name=’gotoPageNo’]”).val(“”);
$(“input[name=’gotoPageNo’]”).focus();
}
return false;
}
</script>
</#macro>

 

转载于:https://my.oschina.net/yunte/blog/1529706

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Spring Boot 中使用 Freemarker 自定义标签,可以通过以下步骤实现: 1. 创建一个自定义标签类,继承 `freemarker.template.TemplateDirectiveModel` 接口,并实现其中的 `execute` 方法,该方法用于处理自定义标签的逻辑。 ```java @Component public class CustomTagDirective implements TemplateDirectiveModel { @Autowired private UserService userService; // 举例注入一个服务类 @Override public void execute(Environment environment, Map params, TemplateModel[] loopVars, TemplateDirectiveBody body) throws TemplateException, IOException { // 处理自定义标签逻辑,可以使用 environment、params、body 等参数 String userId = params.get("userId").toString(); User user = userService.getUserById(userId); environment.getOut().write(user.getName()); } } ``` 2. 在 Spring Boot 的配置文件中注册自定义标签类。 ```java @Configuration public class FreemarkerConfig { @Autowired private CustomTagDirective customTagDirective; @Bean public FreeMarkerConfigurer freeMarkerConfigurer() { FreeMarkerConfigurer configurer = new FreeMarkerConfigurer(); configurer.setTemplateLoaderPath("classpath:/templates"); Map<String, Object> variables = new HashMap<>(); variables.put("customTag", customTagDirective); configurer.setFreemarkerVariables(variables); return configurer; } } ``` 3. 在 Freemarker 模板中使用自定义标签。 ```html <#assign userId = "1" /> <@customTag userId=userId /> ``` 在以上代码中,我们首先通过 `<#assign>` 定义了一个变量 `userId`,然后通过 `<@customTag>` 调用自定义标签,并将 `userId` 作为参数传入。 这样就可以在 Spring Boot 中使用自定义Freemarker 标签了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值