freemaker分页模板
<link href="${base}/res/pra/css/style.css" rel="stylesheet" type="text/css" />
<script type="text/javascript" src="${base}/res/basic/js/jquery/jqPaginator.min.js"></script>
<#--
表格标签:用于显示列表数据。
value:列表数据,可以是Pagination也可以是List。
class:table的class样式。默认"pn-ltable"。
sytle:table的style样式。默认""。
width:表格的宽度。默认100%。
-->
<#macro table value listAction="v_list.do" class="tablelist" style="" theadClass="" tbodyClass="" width="" selfPage="" pageId="pagination" pageNoName="pageNo" pageSizeName="pageSize" pageSizeValue="" gotoPageFunction="_gotoPage" checkFieldFunction="checkField">
<table class="${class}" <#if style?has_content>style="${style}"</#if> <#if width?has_content>width="${width}"</#if>>
<#if value?is_sequence><#local pageList=value/><#else><#local pageList=value.list/></#if>
<#list pageList as row>
<#if row_index==0>
<#assign i=-1/>
<thead <#if theadClass?has_content>class="${theadClass}"</#if>><tr><#nested row,i,true/></tr></thead>
</#if>
<#assign i=row_index has_next=row_has_next/>
<#if row_index==0><tbody <#if tbodyClass?has_content>class="${tbodyClass}"</#if>><tr><#else><tr></#if><#nested row,row_index,row_has_next/>
<#if !row_has_next>
</tr></tbody>
<#else>
</tr>
</#if>
</#list>
</table>
<#if !value?is_sequence>
<div class="pagin" id="pagin">
<div class="message">共<i class="blue">${value.totalCount}</i>条记录,当前显示第 <i class="blue">${value.pageNo}/${value.totalPage}</i> 页 每页显示 <input name="${pageSizeName!}" value="<#if pageSizeValue?? && pageSizeValue?has_content>${pageSizeValue!}<#else>${pageSize!20}</#if>" style="width:35px;" onchange="${checkFieldFunction}(this.value)"> 条</div>
<ul class="paginList" id="${pageId}"></ul>
</div>
<script type="text/javascript">
$.jqPaginator('#${pageId}', {
totalPages: ${value.totalPage},
visiblePages: 10,
currentPage: ${value.pageNo},
activeClass: 'current',
prev: '<li class="paginItem"><a href="javascript:;"><span class="pagepre"></span></a></li>',
next: '<li class="paginItem"><a href="javascript:;"><span class="pagenxt"></span></a></li>',
page: '<li class="paginItem"><a href="javascript:;">{{page}}</a></li>',
onPageChange: function (num, type) {
if(type!='init')
<#if selfPage?? && selfPage!="">${selfPage}(num)<#else>${gotoPageFunction}(num)</#if>;
}
});
function ${gotoPageFunction}(pageNo) {
try{
var tableForm = getTableForm();
$("input[name='${pageNoName}']").val(pageNo);
tableForm.action="${listAction}";
tableForm.onsubmit=null;
tableForm.submit();
} catch(e) {
alert('_gotoPage('+pageNo+')方法出错');
}
}
function ${checkFieldFunction}(val)
{
var tableForm = getTableForm();
$("input[name='${pageSizeName}']").val(val);
tableForm.action="${listAction}";
tableForm.onsubmit=null;
tableForm.submit();
}
</script>
</#if>
<script type="text/javascript">
$('.tablelist tbody tr:odd').addClass('odd');
</script>
</#macro>
<form id="tableForm" method="post">
<@e.hidden name="pageNo" value="${pageNo!}"/>
<@e.hidden name="name" value="${name!}"/>
<@e.hidden name="lesson" value="${lesson!}"/>
<@e.hidden name="teacher" value="${teacher!}"/>
<@e.hidden name="type" value="${type!}"/>
<@e.table class="tablelist" listAction="courseList.jspx" value=page;m,i,has_next>
<#if (i >= 0)>
<div class="course">
<div class="img">
<img src="${base}${(m.ctcdPicture)!}" alt="" />
</div>
<div class="contra">
<div class="w-position">
<p class="left">${(m.ctcdName)!}</p>
<p class="right">价格:¥${(m.price)!}</p>
</div>
<div class="dan-xian"></div>
<div class="text-frame">
<div class="text">
视频课程:<span class="blue">${(m.ctcdLesson)!}</span>课时
</div>
<div class="text">
模拟试卷:<span class="blue">${(m.ctcdImitatePaper)!}</span>套
</div>
<div class="text">课程简介:${(m.ctcdSummary)!}</div>
</div>
<div class="btn">
<a href="course_listen.html"><div class="bg st"></div>
</a> <a href=""><div class="bg ckxq"></div>
</a>
</div>
</div>
</div>
</#if>
</@e.table>
</form>
后台代码:
public String courseList(HttpServletRequest request,Integer pageNo, Integer pageSize, ModelMap model) {
CmCheckCycleDef cycleDef = scService.get().getCcdId();
Pagination page = ctcdService.getPage(null, cycleDef.getCcdId(), "",
"", cpn(pageNo), pageSize == null ? CookieUtils.getPageSize(request) : pageSize);
model.addAttribute("page", page);
System.out.println(page.getList().size());
model.addAttribute("linkList", this.getFriendLink());
model.addAttribute("pageNo", pageNo);
model.addAttribute("pageSize", pageSize);
return FrontUtils.getTplPathUrl(FrontUtils.SOLUTION, "",
"course_list");
}
freemaker分页模板的更多相关文章
- 【Java EE 学习 57】【酒店会员管理系统之分页模板书写】
分页一直是一个比较麻烦的问题,特别是在我做的这个系统中更是有大量的分页,为了应对该问题,特地写了一个模板以方便代码重用,该模板包括后台分页的模板.前端显示的模板两部分. 一.分页分析 分页需要三种类型 ...
- Oracle数据库的SQL分页模板
在系统开发过程中,需要对数据进行查询,大部分情况下从数据库中查询的数据量比较大,在系统页面无法全部显示,而且查询全部的数据会影响系统的反应速度,需要对所查询的数据进行分页的查询操作,以此减轻系统的压力 ...
- velocity分页模板
以前用后台java拼接分页代码,不利于修改.找到一份velocity模板. <!-- 分页模板 --> #macro(pager $url $pager) <url class=&q ...
- smarty分页模板(用模板语法写分页)
分页是一个我们经常要用到的.比较基本的小功能,你可以通过定义一个方法或类来对它进行封装.重用.而本文则是通过利用smarty独有的语法,以模版的方式进行封装,从而达到同样的目的. 下面开始具体实现步骤 ...
- 动动手,写个knockout的分页模板
最近一个项目用ASP.NET + knockout开发,很多列表页面都带分页,于是就有了写一个公共的分页模板的想法. 先把template写好: <script type="text/ ...
- SQL Server分页模板
SQL Server分页模板 WITH T AS ( SELECT ROW_NUMBER() OVER(ORDER BY AlbumId ) AS row_number, * FROM (SELECT ...
- freemaker分页备忘
思路:定义一个freemaker宏,接收参数.然后在freemaker页面上import这个文件,把参数传进来在server端渲染. 分页标签:pager.ftl <#-- 自定义的分页指令. ...
- ThinkPHP自定义分页模板
TpPageHelper.php <?php namespace tool; use think\Paginator; class TpPageHelper extends Paginator ...
- js分页模板
/** *参数说明: *currentPage:当前页数 *countPage:总页数 *changeMethod:执行java后台代码的js函数,即是改变分页数据的js函数 */ function ...
随机推荐
- cocos2dx3.4 分割plist图片
如果想要修改一个plist文件新打包成plist,而此刻原来的小图都找不到了,那只能把plist分解了,代码如下: void UiManage::DecodePlist(string imgPath, ...
- UGUI-组件
2015-06-22 UGUI 组件 Canvas 画布 The Canvas component represents the abstract space in which the UI is l ...
- asp.net中对象的序列化,方便网络传输
对象序列化 是将对象状态转换为可保持或传输的格式的过程.反序列化 是将流转换为对象序列化和反序列化相结合 可以使对象数据轻松的存储和传递 在 .NET 中,如果是对象可序列化,需要在 声明对象的开始部 ...
- Linux中crond服务与crontab用法
需要写个在Linux下定时更新系统的脚本,man crondtab 不甚详细,现将网络上的介绍列举如下: crontab是一个很方便的在unix/linux系统上定时(循环)执行某个任务的程序使用cr ...
- POJ 2186 Popular Cows(Tarjan)
http://poj.org/problem?id=2186 题意 :给你n头牛,m对关系,每对关系由两个编号组成,u和v代表着u认为v是受欢迎的,如果1认为2是受欢迎的,2认为3是受欢迎的,那1认为 ...
- [Gauss]HDOJ3976 Electric resistance
题意: 一看图就明白了 要求的是1与n端点间的等效电阻 重点在于转化成考虑电流 根据KCL定理:在任一瞬间流出(流入)该节点的所有电流的代数和恒为零 U = IR 可以令1点的电势为零 那么n点的电势 ...
- iOS开发UI篇—UITabBarController生命周期(使用storyoard搭建)
iOS开发UI篇—UITabBarController生命周期(使用storyoard搭建) 一.UITabBarController在storyoard中得搭建 1.新建一个项目,把storyb ...
- [wikioi]均分纸牌
这是一道归为贪心题...http://wikioi.com/problem/1098/ 参考:http://www.cnblogs.com/taoziwel/articles/1859984.html ...
- comm命令——
comm命令 :对已经有序的文件进行比较——第一列只在文件1中出现的文件,第二列只在文件2中出现的文件,第三列在文件1和文件2中同事出现的文件 请注意前提条件: comm对文件 ...
- yiic 数据库迁移工具
数据库的结构也同源代码一样随着我们开发的进行而不断的发生着改变.在开发过程中,一般的我们需要像管理我们的源代码一样记录下数据库结构的整个变化过程,以便代码还原到指定版本后,数据库能同步的还原到指定的版 ...