bootstrap-table 列属性_bootstrap table 动态列数

据说bootstrap table非常好用,从入门教程中了解到它的以下主要功能:

由于固定表头意味着固定的列,然而我需要做动态列数的表格啊。

cd2117d18e35cd77b32a7d72598d277c.png

大致思路:bootstrap table在加载表格时,表格的内容按columns参数中的数组来填充。因此,通过动态地生成与columns参数中的数组,我们可以实现动态列名,也就是动态表格。

columns参数格式大致如下:

bffa7b10fcf40d13b67114b711086ee4.png

主要逻辑代码:

通过Object.keys(obj)来获取对象的key的名称,除选项框外,key的数量对应列的数量,在for循环中遍历key的名称,将key填充进title,在销毁后重新创建的bootstrapTable表中,填充好数据源json和columns参数,实现动态扩展表格的列。

var columnsArray = [];

columnsArray.push({field: "state", checkbox: true});

for (var i = 0; i < (Object.keys(json[0])).length; i++) {//Object.keys(obj) 获取key名称

var property = (Object.keys(json[0]))[i];//id username

columnsArray.push({

"title": property,

"field": property,

switchable: true,

sortable: true

});

}

$('#table').bootstrapTable('destroy').bootstrapTable({

data:json,

toolbar: '#toolbar',

singleSelect: true,

clickToSelect: true,

sortName: "create_time",

sortOrder: "desc",

pageSize: 15,

pageNumber: 1,

pageList: "[10, 25, 50, 100, All]",

showToggle: true,

showRefresh: true,

showColumns: true,

search: true,

pagination: true,

columns: columnsArray

});

需要注意的是:这里的列名是英文的,如果需要中文的列名的话,最好接口中返回了中文列的名称,将中文列名遍历到一个空的数组中,再取出来填充在title属性后。再有就是,由于所有的属性都通过遍历生成,所以列之间没有差异性,需要通过jquery再丰富一下列的功能。

我的json数据如下:

565ca594d56edda496edc5fc2ced9727.png

我的表格html:

完整js代码:

$("#table").bootstrapTable({

ajax: function (request) {

$.ajax({

type: "GET",

url: "/table",

contentType: "application/json;charset=utf-8",

dataType: "json",

json: 'callback',

success: function (json) {

var columnsArray = [];

columnsArray.push({field: "state", checkbox: true});

for (var i = 0; i < (Object.keys(json[0])).length; i++) {//Object.keys(obj) 获取key名称

var property = (Object.keys(json[0]))[i];//id username

columnsArray.push({

"title": property,

"field": property,

switchable: true,

sortable: true

});

}

$('#table').bootstrapTable('destroy').bootstrapTable({

data: json,

toolbar: '#toolbar',

singleSelect: true,

clickToSelect: true,

sortName: "create_time",

sortOrder: "desc",

pageSize: 15,

pageNumber: 1,

pageList: "[10, 25, 50, 100, All]",

showToggle: true,

showRefresh: true,

showColumns: true,

search: true,

pagination: true,

columns: columnsArray

});

},

error: function () {

alert("错误");

}

});

}

});

表格数据加载效果如下:

ae1168b69866f3906a224c03746c3032.png

希望这篇博客于你有益,不喜勿喷。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值