codecamp

分页

分页功能是很常见的功能,特别是当数据量越来越大的时候,分页查询是必不可少的。 关于查询分页Java后端的开发技术有很多成熟的解决方案,例如如果使用的ORM框架是mybatis的话,有开源的分页插件可以使用,如:Mybatis-PageHelper。 在你引入Java后端的查询分页技术后如何和Dorado的控件结合就是本文要重点说明的。 在dorado的Java端提供了一个Page对象辅助前端控件进行分页处理。

public class Page<T> {
    private int pageSize;//每页记录数
    private int pageNo;//当前要查询数据对应的页号
    private int firstEntityIndex;
    private int lastEntityIndex;


    private Collection<T> entities;//当前分页查询出来的数据
    private int entityCount;//本次查询匹配的总记录数(不考虑分页)
    private int pageCount;

Page对象的最重要的四个属性是: pageSize,pageNo,entities,entityCount Dorado的数据查询是通过前端的Ajax请求触发后端的DataProvider方法的,触发该方法的时候,前端会在ajax请求中注入pageSize和pageNo信息告诉DataProvider

{
    "action":"load-data",
    "dataProvider":"simpleCRUD#getAll",
    "supportsEntity":false,
    "resultDataType":"v:com.bstek.dorado.sample.data.SimpleCRUD$[ProductType]",
    "pageSize":10,
    "pageNo":2
}

而在分页查询情况下Dorado的引擎通过智能方法适配的时候,会将pageSize和pageNo信息自动封装为Page对象,并作为DataProvider方法的参数传入:

@DataProvider
public void getAll(Page<Product> page) {
    int pageNo = page.getPageNo();//获取客户端传上来的pageNo信息
    int pageSize = page.getPageSize();//获取客户端传上来的pageSize信息
}

在这个方法中,我们就可以通过page参数获取客户端传上来的pageNo和pageSize信息。进而调用自己的业务逻辑层或dao层进行数据查询。 当然查询的最后结果是要返回到前台的,处理的办法还是通过Page对象:

@DataProvider
public void getAll(Page<Product> page) {
    int pageNo = page.getPageNo();
    int pageSize = page.getPageSize();
    PageHelper.startPage(pageNo, pageSize);
    ArrayList<Product> list = productDao.getProductList();
    PageInfo<Product> pageInfo = new PageInfo<Product>(list);
    page.setEntities(list);
    page.setEntityCount(pageInfo.getTotal());
}

上述代码中的productDao的实现是一个示例,采用的PageHelper的写法,实际场景要看开发的项目的分页实现框架决定的。

查询参数
数据绑定
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }