LayUI+PageHelper实现分页插件

尹浩亮_Neuedu_yinhaoliang@neusoft.com


Mybatis分页插件PageHelper

在MyBatis中使用PageHelper 

官网 https://pagehelper.github.io/

首先要在pom.xml中配置PageHelper的依赖

在http://www.mvnrepository.com/中可以发现pagehelper有4.x和5.x两个版本,用法有所不同,并不是向下兼容,在使用5.x版本的时候可能会报错

xml

<dependency>

    <groupId>com.github.pagehelper</groupId>

    <artifactId>pagehelper</artifactId>

    <version>4.2.1</version>

</dependency>  

在Mybatis的配置文件中配置PageHelper插件

假如不配置在后面使用PageInfo类时就会出现问题,输出结果的PageInfo属性值基本上都是错的

配置如下

<plugins>

        <!-- com.github.pagehelper为PageHelper类所在包名 -->

        <plugin interceptor="com.github.pagehelper.PageHelper">

            <property name="dialect" value="mysql"/>

            <!-- 该参数默认为false -->

            <!-- 设置为true时,会将RowBounds第一个参数offset当成pageNum页码使用 -->

            <!-- 和startPage中的pageNum效果一样-->

            <property name="offsetAsPageNum" value="false"/>

            <!-- 该参数默认为false -->

            <!-- 设置为true时,使用RowBounds分页会进行count查询 -->

            <property name="rowBoundsWithCount" value="false"/>

            <!-- 设置为true时,如果pageSize=0或者RowBounds.limit = 0就会查询出全部的结果 -->

            <!-- (相当于没有执行分页查询,但是返回结果仍然是Page类型)-->

            <property name="pageSizeZero" value="true"/>

            <!-- 3.3.0版本可用 - 分页参数合理化,默认false禁用 -->

            <!-- 启用合理化时,如果pageNum<1会查询第一页,如果pageNum>pages会查询最后一页 -->

            <!-- 禁用合理化时,如果pageNum<1或pageNum>pages会返回空数据 -->

            <property name="reasonable" value="true"/>

        </plugin>

    </plugins>

dialect:标识是哪一种数据库,设计上必须。

offsetAsPageNum:将RowBounds第一个参数offset当成pageNum页码使用

rowBoundsWithCount:设置为true时,使用RowBounds分页会进行count查询

reasonable:value=true时,pageNum小于1会查询第一页,如果pageNum大于pageSize会查询最后一页

注:上面的配置只针对于pagehelper4.x版本的.   

项目中使用方法和结果 

在配置完mybatis后,看下pagehelper的业务用法,就以分页查询用户列表为例

添加查询所以用户的mapper接口.我这块使用的注解

@Select("SELECT * FROM country")

List<Country> getAllCountrys();

重点来了,然后在service中,先开启分页,然后把查询结果集放入PageInfo中

public PageInfo listUserByPage(int pageNum, int pageSize) {

        PageHelper.startPage(pageNum, pageSize);

        List<UserVo> userVoList=userMapper.listUser();

        PageInfo pageInfo=new PageInfo(userVoList);

        return pageInfo;

    }

PageHelper.startPage(pageNum, pageSize);这句非常重要,这段代码表示分页的开始,意思是从第pageNum页开始,每页显示pageSize条记录。

PageInfo这个类是插件里的类,这个类里面的属性会在输出结果中显示,

使用PageInfo这个类,你需要将查询出来的list放进去.

PageHelper输出的数据结构 

然后在controller层调用该方法设置对应的pageNum和pageSize就可以了,我设置pageNum为1, pageSize为3,看个输出结果吧

PageInfo{pageNum=1, pageSize=3, size=3, startRow=1, 

endRow=3, total=3, pages=1, list=Page{count=true,

pageNum=1, pageSize=3, startRow=0, endRow=3, total=3,

pages=1, countSignal=null, orderBy='null',

orderByOnly=false, reasonable=true,

pageSizeZero=true}, prePage=0, nextPage=0,

isFirstPage=true, isLastPage=true,

hasPreviousPage=false, hasNextPage=false,

navigatePages=8, navigateFirstPage1,

navigateLastPage1, navigatepageNums=[1]}

PageInfo类里面的属性 

pageNum当前页

pageSize每页的数量

size当前页的数量

orderBy排序

startRow当前页面第一个元素在数据库中的行号

endRow当前页面最后一个元素在数据库中的行号

total总记录数(在这里也就是查询到的用户总数)

pages总页数 (这个页数也很好算,每页5条,总共有11条,需要3页才可以显示完)

list结果集

prePage前一页

nextPage下一页

isFirstPage是否为第一页

isLastPage是否为最后一页

hasPreviousPage是否有前一页

hasNextPage是否有下一页

navigatePages导航页码数

navigatepageNums所有导航页号

navigateFirstPage导航第一页

navigateLastPage导航最后一页

firstPage第一页

lastPage最后一页

最后转为json格式 

导包 

<dependency>

  <groupId>com.alibaba</groupId>

  <artifactId>fastjson</artifactId>

  <version>1.2.47</version>

</dependency>

@Override

    protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {

        resp.setContentType("text/html;charset=utf-8");

        PageInfo<Country> countryPageInfo = new PageService().listUserByPage(1, 3);

        System.out.println(countryPageInfo);

        List<Country> list = countryPageInfo.getList();

        String s = JSON.toJSONString(countryPageInfo);

        resp.getWriter().write(s);

    }

前端使用jQuery+layui发送数据 

HTML部分

<table class="layui-table">

<thead>

<tr>

<th> <input type="checkbox" name="" value=""> </th>

<th> ID </th> <th> 标题 </th>

<th> 分类 </th> <th> 来源 </th>

<th> 更新时间 </th> <th> 浏览次数 </th>

<th> 操作 </th> <th> 操作 </th> <th> 操作 </th>

<th> 操作 </th>

</tr>

</thead>

<tbody id="tbody"> </tbody>

</table>

<div id="page"></div>   //这个为分页的DIV

jquery部分

            var datas;

            function pages(pageNum,pageSize) {

                $.ajax({

                    type:"post",

                    url:"/MavenDemos_war_exploded/page.do",

                    data:{

                        "pageNum":pageNum,

                        "pageSize":pageSize

                    },

                    dataType:"json",

                    async:false,

                    success:function (data1) {

                        console.log(data1);

                        //加载后台返回的List集合数据

                        datas = data1;

                        data = data1.list;

                        for (var i = 0; i < data.length; i++) {

                            var td = $("<td></td>").text(data[i].id);

                            var td2 = $("<td></td>").text(data[i].userName);

                            var td3 = $("<td></td>").text(data[i].passWord);

                            var td4 = $("<td></td>").text(data[i].email);

                            var td5 = $("<td></td>").text(data[i].phone);

                            var td6 = $("<td></td>").text(data[i].question);

                            var td7 = $("<td></td>").text(data[i].answer);

                            var td8 = $("<td></td>").text(data[i].role);

                            var td9 = $("<td></td>").text(data[i].create_time);

                            var td10 = $("<td></td>").text(data[i].update_time);

                            var td11 = $("<td></td>").html("<a title=\"编辑\" onclick=\"question_edit('编辑','question-edit.html','4','','510')\"\n" +

                                "                              class=\"ml-5\" style=\"text-decoration:none\">\n" +

                                "                                <i class=\"layui-icon\">&#xe642;</i>\n" +

                                "                            </a> <a title=\"删除\"  onclick=\"question_del(this,'1')\"\n" +

                                "                              style=\"text-decoration:none\">\n" +

                                "                                <i class=\"layui-icon\">&#xe640;</i>\n" +

                                "                            </a>");

                            var tr = $("<tr></tr>").append(td, td2, td3, td4,td5,td6,td7,td8,td9,td10,td11);

                            $('#tbody').append(tr);

                        }

                    },

                    error :function (response) {

                        console.log(response);

                    }

                })

            }

            var pageSize = 2;

            pages(1,pageSize); 

layui部分

laypage({

    cont: 'page'

    ,count: datas.total

    ,pages: datas.pages

    ,first: datas.firstPage

    ,last: datas.lastPage

    ,prev: '<em><</em>'

    ,next: '<em>></em>'

    , limit: pageSize                      //每页显示条数

    , curr: 1                        //起始页

    , groups: 5                      //连续页码个数

    , first: 1                      //首页文本

    , last: datas.pages                    //尾页文本

    //跳转页码时调用

    , jump: function (obj, first) { //obj为当前页的属性和方法,第一次加载first为true

        //非首次加载 do something

            //清空以前加载的数据

            $('#tbody').empty();

            //调用加载函数加载数据

            pages(obj.curr,obj.limit);

    }

});

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,911评论 5 460
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 82,014评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 142,129评论 0 320
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,283评论 1 264
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,159评论 4 357
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,161评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,565评论 3 382
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,251评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,531评论 1 292
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,619评论 2 310
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,383评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,255评论 3 313
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,624评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,916评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,199评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,553评论 2 342
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,756评论 2 335

推荐阅读更多精彩内容