bootstrapr表格父子框_JS组件系列——表格组件神器:bootstrap table(三:终结篇,最后的干货福利)...

本文作为bootstrap table系列终结篇,详述了表格的行样式设置、行内编辑、行列合并和数据导出功能。通过实例代码展示如何实现不同状态订单的背景色、行内编辑保存、行列合并以及数据导出到excel等。同时指出行内编辑可能引发的数据库频繁操作问题和导出功能在IE浏览器的兼容性问题。
摘要由CSDN通过智能技术生成

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

bootstrap table系列:

一、效果展示

1、表格行样式

比如我们有一个显示订单页面的需求,不同状态的订单显示不同的颜色,如图:

2、表格行内编辑

第一篇的时候有园友就问过博主是否可以支持行内编辑的效果,答案是肯定的。我们先来看看效果:

编辑前

点击某个单元格数据

编辑后完成后

3、表格行列合并

关于行列合并的需求博主觉得是非常常见的,尤其是做页面报表的时候需要用到。先来看看效果:

当前页显示不全,点击进入看看。怎么样?效果还不错吧。

4、表格数据导出

关于表格数据导出,bootstrap table支持三种模式的导出:basic、all、selected。也就是当前页数据导出、所有数据导出、选中数据导出。并且支持导出多种类型的文件,比如常见的excel、xml、json等格式。

导出当前页到excel

导出表格所有数据

导出选中行数据

至于其他类型的文件的导出,和excel基本相同,就不做效果展示了。

二、表格行样式代码示例

关于表格行的样式设置,其他是它一个最基础的功能,为什么要把它放在第三篇?是因为博主觉得这功能可能到处都用得着。当然,效果并不难,自己用jQuery设置tr的背景色也可以实现,但是博主觉得,既然bootstrap table提供了机制设置行的背景色,我们何不用它内置的api呢。我们看看如何实现。

初始化表格的时候

//初始化Table$('#tb_order').bootstrapTable({

url:'/TableStyle/GetOrder', //请求后台的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: true, //是否显示表格搜索,此搜索是客户端搜索,不会进服务端,所以,个人感觉意义不大

strictSearch: true,

showColumns:true, //是否显示所有的列

showRefresh: true, //是否显示刷新按钮

minimumCountColumns: 2, //最少允许的列数

clickToSelect: true, //是否启用点击选中行

height: 500, //行高,如果没有设置height属性,表格自动根据记录条数觉得表格高度

uniqueId: "ID", //每一行的唯一标识,一般为主键列

showToggle: true, //是否显示详细视图和列表视图的切换按钮

cardView: false, //是否显示详细视图

detailView: false, //是否显示父子表

rowStyle: function(row, index) {//这里有5个取值代表5中颜色['active', 'success', 'info', 'warning', 'danger'];

var strclass = "";if (row.ORDER_STATUS == "待排产") {

strclass= 'success';//还有一个active

}else if (row.ORDER_STATUS == "已删除") {

strclass= 'danger';

}else{return{};

}return{ classes: strclass }

},

columns: [{

checkbox:true}, {

field:'ORDER_NO',

title:'订单编号'}, {

field:'ORDER_TYPE',

title:'订单类型'}, {

field:'ORDER_STATUS',

title:'订单状态'}, {

field:'REMARK',

title:'备注'}, ]

});

其实重点就在这个参数里面:

rowStyle: function(row, index) {//这里有5个取值代表5中颜色['active', 'success', 'info', 'warning', 'danger'];

var strclass = "";if (row.ORDER_STATUS == "待排产") {

strclass= 'success';//还有一个active

}else if (row.ORDER_STATUS == "已删除") {

strclass= 'danger';

}else{return{};

}return{ classes: strclass }

},

bootstrap table支持5中表格的行背景色,分别是'active', 'success', 'info', 'warning', 'danger'这五种,至于每种对应的背景颜色,将代码运行起来就可看到。关于这个方法的返回值,博主第一次用的时候也研究了好久,按照bootstrap table的规则,必须返回一个json格式的对象型如: { classes: strclass } 。

三、表格行内编辑代码示例

关于表格行内编辑,需要使用bootstrap table扩展的几个js文件。

1、引入额外的js文件

2、在cshtml页面定义表格时,添加两个属性

部门名称

上级部门

部门级别

描述

如果是在js里面初始化,写法如下:

{

field:"name",

title:"名称",

editable:true}

3、在js里面初始化表格的时候注册编辑保存的事件

$('#tb_departments').bootstrapTable({

url:'/Editable/GetDepartment', //请求后台的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, //每页的记录行数(*)

onEditableSave: function(field, row, oldValue, $el) {

$.ajax({

type:"post",

url:"/Editable/Edit",

data: { strJson: JSON.stringify(row) },

success:function(data, status) {if (status == "success") {

alert("编辑成功");

}

},

error:function() {

alert("Error");

},

complete:function() {

}

});

}

});

重点还是看看这个事件的处理方法

onEditableSave: function(field, row, oldValue, $el) {

$.ajax({

type:"post",

url:"/Editable/Edit",

data: { strJson: JSON.stringify(row) },

success:function(data, status) {if (status == "success") {

alert("编辑成功");

}

},

error:function() {

alert("Error");

},

complete:function() {

}

});

}

对应的方法里面需要自己处理保存的逻辑。四个参数field, row, oldValue, $el分别对应着当前列的名称、当前行数据对象、更新前的值、编辑的当前单元格的jQuery对象。

四、表格行列合并代码示例

表格的行列合并功能不用引用其他的js文件,只需要在cshtml页面使用table的colspan和rowspan即可实现。

1、cshtml页面

第一季度

第二季度

第三季度

第四季度

年度汇总

一月

二月

三月

第一季度

四月

五月

六月

第二季度

七月

八月

九月

第三季度

十月

十一月

十二月

第四季度

2、js初始化并无特殊

$('#tb_report').bootstrapTable({

url:'/GroupColumns/GetReport', //请求后台的URL(*)

method: 'get', //请求方式(*)

toolbar: '#toolbar', //工具按钮用哪个容器

striped: true, //是否显示行间隔色

cache: false, //是否使用缓存,默认为true,所以一般情况下需要设置一下这个属性(*)

pagination: true, //是否显示分页(*)

sortOrder: "asc", //排序方式

queryParams: oTableInit.queryParams,//传递参数(*)

sidePagination: "server", //分页方式:client客户端分页,server服务端分页(*)

pageNumber: 1, //初始化加载第一页,默认第一页

pageSize: 10, //每页的记录行数(*)

pageList: [10, 25, 50, 100], //可供选择的每页的行数(*)});

怎么样,有没有很简单。当然,有人说了,你都可以不用js初始化,直接在cshtml里面用table的属性去设置url、分页等信息。确实,如果我们看过它的api,会发现它初始化的每一个属性都对应一个table的属性。型如

如果你的表格没有一些特殊的事件需要处理,这样是完全没有问题的。

五、表格数据导出代码示例

表格数据的导出功能也需要一些扩展的js支持。

1、引入额外的js文件

2、js初始化的时候

$('#tb_departments').bootstrapTable({

url:'/Export/GetDepartment', //请求后台的URL(*)

method: 'get', //请求方式(*)

toolbar: '#toolbar', //工具按钮用哪个容器

striped: true, //是否显示行间隔色

cache: false, //是否使用缓存,默认为true,所以一般情况下需要设置一下这个属性(*)

pagination: true, //是否显示分页(*)

sortable: false, //是否启用排序

sortOrder: "asc", //排序方式

queryParams: oTableInit.queryParams,//传递参数(*)

sidePagination: "client", //分页方式:client客户端分页,server服务端分页(*)

pageNumber: 1, //初始化加载第一页,默认第一页

pageSize: 10, //每页的记录行数(*)

pageList: [10, 25, 50, 100], //可供选择的每页的行数(*)

clickToSelect:true,

showExport:true, //是否显示导出

exportDataType: "basic", //basic', 'all', 'selected'.

columns: [{

checkbox:true}, {

field:'Name',

title:'部门名称'}, {

field:'ParentName',

title:'上级部门'}, {

field:'Level',

title:'部门级别'}, {

field:'Desc',

title:'描述'}, ]

});

还是来看重点:这两个属性

showExport: true, //是否显示导出

exportDataType: "basic", //basic', 'all', 'selected'.

showExport表示是否显示导出的按钮,exportDataType表示导出的模式是当前页、所有数据还是选中数据。

六、总结

以上就是功能的效果以及实现的简单代码。博主发现有几个问题有待解决。

1、行内编辑的功能是每一个单元格提交到后台,这样会造成数据库的频繁操作,感觉不太合适。不知道有没有更好的方式,每行提交到后台。

2、导出的功能虽然很好用,但是遗憾的是不支持IE浏览器,博主试过官网上面的example,好像IE也导出不了。待验证。

源码提供出来,园友们有兴趣可以看看。源码下载。

最近打算做点自己的东西出来,将博客里面的一些好的技术融合进去。有项目合作的小伙伴赶快联系博主吧!

欢迎各位转载,但是未经作者本人同意,转载文章之后必须在文章页面明显位置给出作者和原文连接,否则保留追究法律责任的权利!

Bootstrap-table 是一款基于Bootstrap的jQuery表格插件,可以实现表格的各种功能,例如排序、搜索、分页等。而Bootstrap-table也提供了父子表功能,可以方便地实现表格的嵌套展示。下面是父子表的入门教程。 首先,我们需要准备一个包含父子关系的数据源。例如: ``` var data = [ { id: 1, name: 'Parent 1', children: [ { id: 2, name: 'Child 1-1' }, { id: 3, name: 'Child 1-2' } ] }, { id: 4, name: 'Parent 2', children: [ { id: 5, name: 'Child 2-1' } ] } ]; ``` 其中,每个父节点都有一个children属性,代表它的子节点。接着,我们需要在表格中配置父子表的相关参数。例如: ``` <table data-toggle="table" data-url="data.json" data-detail-view="true" data-detail-formatter="detailFormatter"> <thead> <tr> <th data-field="id">ID</th> <th data-field="name">Name</th> </tr> </thead> </table> <script> function detailFormatter(index, row) { var html = []; $.each(row.children, function (key, child) { html.push('<p>' + child.name + '</p>'); }); return html.join(''); } </script> ``` 在上述代码中,我们配置了data-detail-view和data-detail-formatter参数,分别表示开启父子表功能和定义子表的展示方式。而在detailFormatter函数中,我们将子节点的名称拼接成了一段HTML字符串,并返回给父表格的插件。 最后,我们需要引入Bootstrap-table的相关文件,并初始化表格: ``` <link rel="stylesheet" href="https://cdn.bootcss.com/bootstrap/3.3.7/css/bootstrap.min.css"> <link rel="stylesheet" href="https://cdn.bootcss.com/bootstrap-table/1.11.1/bootstrap-table.min.css"> <script src="https://cdn.bootcss.com/jquery/3.2.1/jquery.min.js"></script> <script src="https://cdn.bootcss.com/bootstrap/3.3.7/js/bootstrap.min.js"></script> <script src="https://cdn.bootcss.com/bootstrap-table/1.11.1/bootstrap-table.min.js"></script> <script> $(function () { $('table').bootstrapTable({ data: data }); }); </script> ``` 这样,我们就成功地实现了一个父子表的展示效果。当我们点击父表格的某一行时,就会展示出它所对应的子表格
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值