欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

表格展示利器 Bootstrap Table实例代码

程序员文章站 2022-04-28 23:42:25
1.bootstrap bable 全部数据导出分析      在表格导出数据中,发现设置了分页参数,导出的数据仅为表格加载的分页...

1.bootstrap bable 全部数据导出分析

     在表格导出数据中,发现设置了分页参数,导出的数据仅为表格加载的分页参数数据,于是,针对这样的情况,通过设置分页参数的值,使表格可以加载更多的数据,可达到导出所有数据的功能需求。然而,在实际的实验中,发现此方案存在以下问题:

  • 表格一次加载一千条数据时,网页响应速度太慢,加载数据等待时间严重过长。(一分钟左右)
  • bootsrtap table 的文件导出是纯前端的js导出模式,它的数据源只能为表格中的数据集合

    分析产生上述问题的原因,不难发现,html页面在渲染的时候,一次渲染过多的节点,网页性能必然降低。而通过去分析table-export.js中的导出源码,发现导出文件是以表格为数据源,导出多数据时,必然需要表格加载更多的数据,所以这样的循环,导致导出功能在实际项目中,导出特别耗时,应用不理想。要解决这样的问题,目前可采用如下两种方法:

  • 修改table-export.js中的导出模块源码,当ajax从后台请求到数据成功后,不在渲染数据到bootstrap table中去,而是直接作为数据源提供给导出模块。(目前这样的方案,感觉编写js函数需要的逻辑比较复杂)
  • 前端调用java程序中,成熟的导出文件功能,利用java程序处理文件导出。

     本次测试文件导出时,采用了java后台程序处理的方案。具体操作如下:

前端界面仿造bootstrap table的js函数,编写一个导出所有文件的按钮利用java程序,调用sxssfworkbook组件,导出指定数据到excel表中

构建导出按钮

     构建导出按钮,修改bootstrap-table.js中的定义事项,加入一个showexportall参数,定义展示样式即可模拟一个导出按钮,重要实现代码如下:   

 //wanling add exportall button 2017-8-7
  if (this.options.showexportall) {
   html.push(sprintf('<button class="btn' +
     sprintf(' btn-%s', this.options.buttonsclass) +
     sprintf(' btn-%s', this.options.iconsize) +
     '" type="button" name="exportall" aria-label="exportall" title="%s">',
    this.options.formatexportall()),
    sprintf('<i class="%s %s"></i>', this.options.iconsprefix, this.options.icons.exportall),
    '</button>');
  }

最终实现效果如下:

表格展示利器 Bootstrap Table实例代码

java调用sxssfworkbook组件导出文件

     sxssfworkbook官网介绍 http://poi.apache.org/apidocs/org/apache/poi/xssf/streaming/sxssfworkbook.html。它是专门用来处理大量数据写入 excel2007的工具。通过在java后台获取到数据后,传入数据,展示列等信息到sxssfworkbook中,即可完成数据写入到excel并以文件流的方式输出。核心调用代码如下:   

 @override
 public map perform(map inmap) throws bizexception, sysexception {
  inmap.put("start", integer.valueof(0));
  inmap.put("limit", sysconfighelper.getexportbatchsize());
  map result = overtime.queryaction(inmap);
  string exportfilename = "加班信息表";
  list resutlist = (list) result.get(commonattribute.rows);
  list queryresultcolumnnames = new arraylist(arrays.aslist("createbydesc", "overtimedate", "begintime", "endtime", "overtimehour", "checkpersondesc", "overtimestatus", "projectnamedesc", "overtimeaddressdesc", "eatmoney", "taximoney", "overtimeremark"));
  list queryresultcolumnfriendlynames = new arraylist(arrays.aslist("加班人", "加班日期", "加班开始时间", "加班结束时间", "加班小时", "审核人", "审核状态", "所属项目", "加班地点", "加班餐费", "加班车费", "备注"));
  //list<double> queryresultcolumnwidths = new arraylist(arrays.aslist(65.00, 40.00, 100.00, 120.00, 65.00, 100.00, 65.00, 100.00));
  httpservletresponse response = (httpservletresponse) inmap.get("http_response");
  try {
   exporttoexcelhelper.exportexcel(queryresultcolumnnames,queryresultcolumnfriendlynames,resutlist,false,exportfilename,response);
  } catch (ioexception e) {
   e.printstacktrace();
  }
  return null;
 }
 protected static void exportexcel(list<object> columnfriendlynamelist, list<object> columnlist, list<double> columnwidths, map inmap, outputstream outputstream, boolean... hideseq) {
  boolean hideseq = hideseq.length == 1 && hideseq[0];
  sxssfworkbook workbook = new sxssfworkbook(5000);
  sheet sheet = workbook.createsheet("sheet1");
  initcellstyle(workbook);
  setheaderline(sheet, columnfriendlynamelist, hideseq);
  setdataline(sheet, columnlist, inmap, hideseq);
  setcolumnwidth(sheet, columnwidths);
  outputworkbook(workbook, outputstream);
  resettimestylestr();
 }

导出数据效果

   通过前端自定义的按钮,调用后台的导出文件action,即可导出数据到excel文本中。展示效果如下(部分列数据我手动删除了):

表格展示利器 Bootstrap Table实例代码

2.bootstrap table 数据行修改

   通过调用bootstrap table的扩展js(bootstrap-table-editable.js,bootstrap-editable.js)可设置编辑表格行内数据。前端设置编辑表格数据,界面展示效果如下:

表格展示利器 Bootstrap Table实例代码

   对于修改表格内容时的提示框样式,可修改bootstrap-table-editable.js中的源码处理noeditformatter函数,修改样式参考代码如下:

 var _dont_edit_formatter = false;
    if (column.editable.hasownproperty('noeditformatter')) {
     var process = column.editable.noeditformatter(value, row, index);
     if(!process.hasownproperty('class')){
      process.class = '';
     }
     if(!process.hasownproperty('style')){
      process.style = 'color:#000;text-decoration:none;';
     }
     _dont_edit_formatter = ['<a href="javascript:void(0)" rel="external nofollow" rel="external nofollow" ',
      ' data-name="'+process.filed+'"',
      ' data-pk="' + row[that.options.idfield] + '"',
      ' data-value="' + process.value + '"',
      ' class="'+process.class+'" style="'+process.style+'"',
      '>' + process.value + '</a>'
     ].join('');
    }

    if (_dont_edit_formatter === false) {
     return ['<a href="javascript:void(0)" rel="external nofollow" rel="external nofollow" ',
      ' data-name="' + column.field + '"',
      ' data-pk="' + row[that.options.idfield] + '"',
      ' data-value="' + result + '"',
      editabledatamarkup.join(''),
      '>' + value + '</a>'
     ].join('');
    } else {
     return _dont_edit_formatter;
    }

前端页面调用时,参考代码如下:

loadcharts: function () {
  var me = this;
  var tb_departments = me.getcmp("overtimetable").bootstraptable({
   method: 'post',      //请求方式(*)
   height: mp.const.datagridheight,
   toolbar: '#checkovertimeinfo_toolbar',    //工具按钮用哪个容器
   striped: true,      //是否显示行间隔色
   cache: false,      //是否使用缓存,默认为true,所以一般情况下需要设置一下这个属性(*)
   pagination: true,     //是否显示分页(*)
   sortable: true,      //是否启用排序
   sortorder: "asc",     //排序方式
   sidepagination: "server",   //分页方式:client客户端分页,server服务端分页(*)
   pagenumber: 1,      //初始化加载第一页,默认第一页
   pagesize: 20,      //每页的记录行数(*)
   pagelist: [10, 20, 25, 30],  //可供选择的每页的行数(*)
   //search: true,      //是否显示表格搜索,此搜索是客户端搜索,不会进服务端,所以,个人感觉意义不大
   strictsearch: true,
   singleselect:false,
   showcolumns: true,     //是否显示所有的列
   showtoggle:true,     //是否显示详细视图和列表视图的切换按钮
   //showrefresh: false,     //是否显示刷新按钮
   minimumcountcolumns: 1,    //最少允许的列数
   //clicktoselect: true,    //是否启用点击选中行
   cardview: false,     //是否显示详细视图
   detailview: false,     //是否显示父子表
   showheader: true,
   oneditablesave: function (field, row, oldvalue, $el) {
    //单行数据修改后,保存到后台
    var param={};
    var listuuid=[];
    listuuid[0]=row.uuid;
    param.listuuid=listuuid;
    param.overtimestatus=row.overtimestatus;
    mp.doaction("sccq-overtime-update", param, function(data)
    {
     if(data.success)
     {
      mp.msg.info('审核操作完成');
     }
     me.ajaxgetdata();

    },null, true, true);

   },
   columns: [
    {
     title: "全选",
     field: "select",
     checkbox: true,
     align: "left",//水平居中
     halign: "left",//垂直居中
    }, {
     field: "uuid",
     align: 'center',
     title: "个人分析",
     formatter: function (value) {
      var html = "<a class='easyui-linkbutton l-btn l-btn-small l-btn-plain' name='" + value + "'>" +
       "<span class='l-btn-left l-btn-icon-left'><span class='l-btn-icon icon-search'></span><span class='l-btn-text'>查看</span></span></a> ";
      return html;
     }
    }, {
     align: "left",//水平居中
     halign: "left",//垂直居中
     field: "createbydesc",
     title: "加班人"
    },{
     align: "left",
     halign: "left",
     field: "overtimedate",
     sortable:true,
     title: "加班日期",
     formatter: function (value) {
      return mp.dateformatter(value);
     }
    },
    {
     align: "left",
     halign: "left",
     field: "begintime",
     title: "加班开始时间"
    },
    {
     align: "left",
     halign: "left",
     field: "endtime",
     title: "加班结束时间"
    },
    {
     align: "left",
     halign: "left",
     field: "overtimehour",
     sortable:true,
     title: "加班小时"
    },
    {
     align: "left",
     halign: "left",
     field: "overtimestatus",
     title: "审核状态",
     editable: {
      type: 'select',
      title: "审核状态",
      pk: 1,
      source: [
       {value: 2, text: '审核通过'},
       {value: 3, text: '驳回'}
      ],
      noeditformatter: function (value,row,index) {
       var result;
       if (value == '1' || value == '待审核') {
        result={filed:"overtimestatus",value:"待审核",class:"badge bg-orange",style:"padding:5px 10px;"};
       } else if (value == '2' || value == '审核通过'){
        result={filed:"overtimestatus",value:"审核通过",class:"badge bg-green",style:"padding:5px 10px;"};
       }
       else if (value == '3' || value == '驳回'){
        result={filed:"overtimestatus",value:"驳回",class:"badge bg-red",style:"padding:5px 10px;"};
       }
       return result;
      }
     }
    },
    {
     align: "left",
     halign: "left",
     field: "projectnamedesc",
     sortable:true,
     title: "所属项目"
    },
    {
     align: "left",
     halign: "left",
     field: "overtimeaddressdesc",
     sortable:true,
     title: "加班地点"
    },
    {
     align: "left",
     halign: "left",
     field: "eatmoney",
     sortable:true,
     title: "加班餐费"
    },
    {
     align: "left",
     halign: "left",
     field: "taximoney",
     sortable:true,
     title: "加班车费"
    },
    {
     align: "left",
     halign: "left",
     field: "overtimeremark",
     title: "备注"
    }
   ],
   onpagechange:function(number, size)
   {
    //设置在分页事件触发时,传递分页参数给后台,重新加载数据
    me.querybaseparam.limit=size;
    me.querybaseparam.start=number;
    me.ajaxgetdata();
   },
   onsort: function (name, order) {
    me.querybaseparam.sort=name;
    me.querybaseparam.order=order;
    me.ajaxgetdata();
   },
   onclickrow: function (row, $elepment, field) {
    if (field == 'uuid') {
     //alert("查看页面");
     var params={};
     params.createby=row.createby;
     params.createbydesc=row.createbydesc;
     me.controller.showovertimesingledetail(params);
    }
   }
  });
 },
 ajaxgetdata: function () {
  //加载后台数据
  var me=this;
  var params=mp.getformdata("searchovertimeform_person",this.controller);
  params.querytype=1;
  params.limit= me.querybaseparam.limit;
  params.start= me.querybaseparam.start;
  params.sort= me.querybaseparam.sort;
  params.order= me.querybaseparam.order;
  mp.doaction("sccq-overtime-query", params, function (datas) {
   if (datas.success) {
    me.getcmp("overtimetable").bootstraptable('load', datas);
   }
  }, function (datas) {
   alert("数据加载失败");
  }, true, true);
 }

总结

以上所述是小编给大家介绍的表格展示利器 bootstrap table实例代码,希望对大家有所帮助