web前端设置分页label

2018-12-02  本文已影响0人  summer_oracle

web前端设置分页label

一.思路分析

一般做数据表的分页  前后端的交互数据

  请求携带的数据 pageNum(当前页)   pageSize(每页的记录数)

   后端给前端的数据

   page.getContent()    就是当前页的数据列表

    totals : 总记录数

    totalPages : 总页数

二. 环境材料设置

一般后端根据pageNum和pageSize向后端数据库查询数据

今天我要做的案例是同步数据库某表的solr索引库做分页后端数据的查询

现在就是简单的一个分页查询, 不做其他条件的添加

1.后端代码

    private Map queryPage(Map searchMap){

        Query query =new SimpleQuery("*:*");

        Map map = new HashMap();

        Integer pageNum = (Integer) searchMap.get("pageNum");//获取当前页码

        if(pageNum==null){

            pageNum=1;//前端没有给数据我自己设置

        }

        Integer pageSize = (Integer) searchMap.get("pageSize");//获取每页记录数

        if(pageSize==null){

            pageSize=20;//前端没有给数据我自己设置

        }

        //设置分页

        query.setOffset((pageNum-1)*pageSize);//设置从哪个索引查询

        query.setRows(pageSize);//每页显示的记录数

        HighlightPage page =solrTemplate.queryForPage(query, TbItem.class);

        return map.put("pageList",page.getContent())

     }

2.前端代码:

angularJS代码:

    //定义循环产生页码标签

$scope.buildPageTable =function(){

//1.对于循环产生页码标签,我们只让显示5个

    var maxPageNo= $scope.resultMap.totalPages;//得到最后页码

    var firstPage=1;//开始页码

    var lastPage=maxPageNo;//截止页码

    //2.为了是否显示省略号 创建两个变量

    $scope.firstDot=true;//前面有点

    $scope.lastDot=true;//后边有点

    if($scope.resultMap.totalPages>5){//如果总页数大于5页,显示部分页码

        if($scope.searchMap.pageNum<=3){

            lastPage=5;

            $scope.firstDot=false;//让前页码的点消除

        }else if($scope.searchMap.pageNum>=lastPage-2){

            firstPage=maxPageNo-4;

            $scope.lastDot=false;//让后面页码的点消除

        }else {

        firstPage=$scope.searchMap.pageNum-2;

        lastPage=$scope.searchMap.pageNum+2;

}

}else{

//如果总页数小于=5, 显示所有页码. 前后省略号都消除

        $scope.firstDot=false;

        $scope.lastDot=false;

}

//定义一个数组, 用来装每个页码数,在前端页面循环

    $scope.pageLable = [];

    for (var i=firstPage;i<=lastPage;i++){

        $scope.pageLable.push(i);

    }

}

//定义根据页码查询方法

$scope.queryByPage =function (pageNum) {

    if(pageNum<0 || pageNum>$scope.resultMap.totalPages){

    return ;

    }

    //将传入的pageNum参数赋值给$scope.searchMap.pageNum

    $scope.searchMap.pageNum=pageNum;

    $scope.search();

}

//3.对页码(上一页和下一页)不可用样式的判断

$scope.isTopPage=function () {

    if($scope.searchMap.pageNum==1){

        return true;//不可用

    }else{

        return false;//可用

    }

}

$scope.isEndPage=function () {

if($scope.searchMap.pageNum==$scope.resultMap.totalPages){

        return true;//不可用

    }else{

        return false;//可用

    }

}

上一篇 下一篇

猜你喜欢

热点阅读