当前位置: 移动技术网 > IT编程>开发语言>JavaScript > 表格展示利器 Bootstrap Table实例代码

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

2017年12月12日  | 移动技术网IT编程  | 我要评论
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>');
  }

最终实现效果如下:

java调用sxssfworkbook组件导出文件

     sxssfworkbook官网介绍 。它是专门用来处理大量数据写入 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文本中。展示效果如下(部分列数据我手动删除了):

2.bootstrap table 数据行修改

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

   对于修改表格内容时的提示框样式,可修改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实例代码,希望对大家有所帮助

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网