关于bootstrap table的server分页

首先是bootstrap初始化的表格参数:

// 初始化Table
    oTableInit.Init = function() {
            $(‘#booksTable‘).bootstrapTable({
            url : ‘/TestWeb/booksTable‘, // 请求后台的URL(*)
            method : ‘get‘, // 请求方式(*)
            toolbar : ‘#toolbar‘, // 工具按钮用哪个容器
            striped : true, // 是否显示行间隔色
            cache : false, // 是否使用缓存,默认为true,所以一般情况下需要设置一下这个属性(*)
            pagination : true, // 是否显示分页(*)
            sortable : false, // 是否启用排序
            sortOrder : "asc", // 排序方式
            queryParams : oTableInit.queryParams,// 传递参数(*)
            sidePagination : "server", // 分页方式:client客户端分页,server服务端分页(*)
            pageNumber : 1, // 初始化加载第一页,默认第一页
            pageSize : 10, // 每页的记录行数(*)
            pageList : [ 10, 25, 50, 100 ], // 可供选择的每页的行数(*)
            search : false, // 是否显示表格搜索,此搜索是客户端搜索,不会进服务端,所以,个人感觉意义不大
            strictSearch : false,
            showColumns : true, // 是否显示所有的列
            showRefresh : true, // 是否显示刷新按钮
            minimumCountColumns : 2, // 最少允许的列数
            clickToSelect : true, // 是否启用点击选中行
            height : 500, // 行高,如果没有设置height属性,表格自动根据记录条数觉得表格高度
            uniqueId : "ID", // 每一行的唯一标识,一般为主键列
            showToggle : true, // 是否显示详细视图和列表视图的切换按钮
            cardView : false, // 是否显示详细视图
            detailView : false, // 是否显示父子表
            columns : [ {
                radio : true
            }, {
                field : ‘bookName‘,
                title : ‘书本名称‘
            }, {
                field : ‘price‘,
                title : ‘书本价格‘
            }, {
                field : ‘time‘,
                title : ‘书本入库时间‘
            }, {
                field : ‘status‘,
                title : ‘是否借出‘
            }, ]
        });
    };

然后是前端要传给后端的参数:

oTableInit.queryParams = function(params) {

        /*
        var temp = { //这里的键的名字和控制器的变量名必须一直,这边改动,控制器也需要改成一样的
            limit : params.limit, //页面大小
            offset : params.offset, //页码
            bookName : $("#txt_search_bookName").val()
        };
         */

        if (!params)
            return {
                bookName : $("#txt_search_bookName").val()
            //bookName : "fuck"
            };
        var temp = { // 这里的键的名字和控制器的变量名必须一直,这边改动,控制器也需要改成一样的
            limit : params.limit, // 页面大小
            offset : params.offset, // 页码
            search : params.search,
            bookName : $("#txt_search_bookName").val()
        //bookName : "fuck you"
        };

        return temp;
    };

这里的params是框架的table自动提供的,然后limit是页面大小,就是你一面显示多少行数据,也就是params会把你写的pageSize传过去。

然后这个offset是页码,比如说现在是第一页(limit=10),然后框架帮你传过去的的offset是0也就是从0开始,显示limit个数据,如果是第二页,offset是10,以此类推。

然后是后端的关键代码,server分页关键就是要告诉前端total几行,还有就是一页中的数据rows,rows数据是个json数组,里面每一个数据都是一个表格中行的json对象。看一下关键代码:

public  Map<String,Object> getPageBase(){

        int total=list.size();//list是dao层返回的所有数据的一个list
        Map<String,Object> result = new HashMap<String,Object>();
        List<Object> lists = new ArrayList<Object>();
        //判断总数是否大于页码的大小,大于则按照正常页码获取显示的数据,否则按照数据计算的页码,获取显示数据
        if(total>offset){
            for(int i=offset;i<total && i<(offset+limit);i++){
                lists.add(list.get(i));//lists是要返回给前端的rows数组
            }
        }else{
            int nums=total/limit;
            for(int i=nums*limit;i<total;i++){
                lists.add(list.get(i));
            }
        }
        result.put("total",total);
        result.put("rows",lists);
        return result;

    }

原文地址:https://www.cnblogs.com/wangshen31/p/8439931.html

时间: 2024-12-10 16:01:55

关于bootstrap table的server分页的相关文章

bootstrap table 服务端分页

前端js $(function () { //$('#MDTable').bootstrapTable('destroy'); $("#MDTable").bootstrapTable({ //'destroy' 是必须要加的==作用是加载服务器数据,初始化表格的内容Destroy the bootstrap table. toolbar: '#toolbar', //工具按钮用哪个容器 method: 'get', url: "/MD_All/MD_Data",

bootstrap table两种分页需要的数据不同

先上原帖地址:http://blog.csdn.net/tyrant_800/article/details/50269723 问题描述: 调用$("#show_list_table").bootstrapTable("refresh");刷新table以后,搜索条件可以传入,也请求到了数据,但是就是不在table中展示数据. 最后发现是因为服务器端分页和客户端分页需要的json格式不一样. 原帖内容: 服务器分页/客户端分页的转换,table刷新 bootstra

161221、bootstrap table 实例

bootstrap table 封装了一套完善的数据表格组件,把下面的代码复制一下估计你需要的基本功能都有了,没有的再看看手册对比着我给的实例也能很快的熟悉了 客户端 <!DOCTYPE html> <html> <head>     <meta charset="UTF-8">     <title>Bootstrap-Table</title>     <link rel="stylesheet

bootstrap table 服务器端分页--ashx+ajax

1.准备静态页面 1 <!DOCTYPE html> 2 <html> 3 <head> 4 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 5 <title></title> 6 <meta charset="utf-8" /> 7 <link rel="

bootstrap table 分页后,重新搜索的问题

前提: 自定义搜索且有分页功能,比如搜索产品名的功能. 现象:当搜索充气娃娃的时候返回100条记录,翻到第五页.  这时候搜索按摩棒,数据有200条,结果应该是第一页的记录,但是实际显示的还是第五页的结果.  也就是重新搜索后,pagenumber没有变. 按网上大部分说的:重新设置option就行了 $('#tableList').bootstrapTable({pageNumber:1,pageSize:10}); 以上是解决不了这个问题. 正确做法是 $("#table").bo

使用bootstrap table时不能显示筛选列和分页每页显示的行数

使用bootstrap table时不能显示筛选列和分页每页显示的行数 后来在同事的帮助下,才发现没有引用bootstrap的js文件 <script src="/Scripts/bootstrap/js/bootstrap.js"></script> 这个引用了就可以了

bootstrap table 分页序号递增问题 (转)

原文地址:https://segmentfault.com/q/1010000011040346 如题,怎么在bootstrap table中显示序号,序号递增,并且分页有效,等于是每页10条,第2页的序号可以从11开始到20.之前的是这样写的columns的序号: columns:[{ field: '序号', title: 'number', width:5 , align:'center', switchable:false, formatter:function(value,row,in

JS组件系列——表格组件神器:bootstrap table(三:终结篇,最后的干货福利)

前言:前面介绍了两篇关于bootstrap table的基础用法,这章我们继续来看看它比较常用的一些功能,来个终结篇吧,毛爷爷告诉我们做事要有始有终~~bootstrap table这东西要想所有功能覆盖似乎不太现实,博主挑选了一些自认为比较常用的功能在此分享给各位园友.源码也在这篇统一给出.好了,不多说废话,开始我们的干货之旅吧. bootstrap table系列: JS组件系列——表格组件神器:bootstrap table JS组件系列——表格组件神器:bootstrap table(二

新的表格展示利器 Bootstrap Table Ⅱ

    上一篇文章介绍了Bootstrap Table的基本知识点和应用,本文针对上一篇文章中未解决的文件导出问题进行分析,同时介绍BootStrap Table的扩展功能,当行表格数据修改. 1.Bootstrap Bable 全部数据导出分析 在表格导出数据中,发现设置了分页参数,导出的数据仅为表格加载的分页参数数据,于是,针对这样的情况,通过设置分页参数的值,使表格可以加载更多的数据,可达到导出所有数据的功能需求.然而,在实际的实验中,发现此方案存在以下问题: 表格一次加载一千条数据时,网