BootStrap table表格插件自适应固定表头(超好用)

网友投稿 971 2023-07-08


BootStrap table表格插件自适应固定表头(超好用)

首先是简单的页面形式,大家可以按照平常画表格的方式来创建html表格,然后通过js控制特殊的样式等操作(优点是表格更加直观,方便调整表格样式等,速度快)

当然,也可以只在页面上放一个table标签,之后的所有数据和样式都通过js控制也是可以的,后面会说(优点方便控制修改数据,尤其是ajax方式获取的json格式,但是调整样式比较麻烦)

ps:这个是插件的官网,里面有英文api和例子:http://bootstrap-table.wenzhixin.net.cGlGfxsMnKn/zh-cn/

还有,使用前请引入bootstrap的相关css,js,jquery,以及bootstrap-table的css,js至少这5个基本文件

一,html表格方式

例一:需求,简单的表格数据呈现,表头是两行,还有一个上下浮的箭头

分析:很简单,只需要html就可以实现,按照常规的表格来画,添加上bootstrap-table独有的自定义属性即可,注意如果不使用js请在最开始的table标签中加上data-toggle

html代码:

来耗存

当日

本周

本月

本期

同比

环比

本期

同比

环比

本期

同比

环比

例二:需求,第二个表格后面有个显示进度的自定义单元格,并且第一行要求是做一个合计的统计展示,这两个功能需要用js来设定自定义行列

html代码:

序号

供应商

品种

热值

煤价

标煤单价

当日来煤

累计来煤

月计划量

月计划完成进度

js代码:

//声明用来统计合计(累计来煤,月计划)的变量

var yjhArr=[];

var ljlmArr=[];

//显示进度条的自定义列

function progress (value,row){

var width=parseInt(row.yjhjd);

var red='#e63737';

var blue='#b6ccf4';

yjhArr.push(row.yjhl);

ljlmArr.push(row.ljlm);

return "

}

//计算合计数值的方法

function yjhTotal(){

var subyjh=0;

var subljlm=0;

var row=[];

for(var i=0;i

if(yjhArr[i]==""){

yjhArr[i]=0;

}

subyjh+=parseFloat(yjhArr[i]);

}

for(var j=0;j

if(ljlmArr[j]==""){

ljlmArr[j]=0;

}

subljlm+=parseFloat(ljlmArr[j]);

}

row.push({

id:1,

gys:'合计',

pz:'',

rz:'',

mj:'',

bmdj:'',

drlm:'',

ljlm:subljlm.toFixed(2),

yjhl:subyjh,

yjhjd:'107%'

});

return row

}

分析:自定义行列需要添加data-formatter=‘方法名',其中progress()方法中的参数row,会在表格生成行的时候每生成一行就执行一次并将该行的对象传进来。

二:js方式

通过这种方法,可以很方便的为表格设置参数,处理数据方面十分便捷,尤其是设置请求方式和地址时,不过这个项目暂时只是静态页面,有关数据的以后接触在写上来

例一:同上例一

html:

js:

//表格插件(表一)开始

$('#tableL01').bootstrapTable({

height:268,

//模拟数据

columns: [[{

GlGfxsMnKalign:'center',

valign:'middle',

field: 'lhc',

title: '来耗存',

rowspan:2

}, {

align:'center',

valign:'middle',

field: 'dr',

title: '当日',

colspan:3

}, {

align:'center',

valign:'middle',

field: 'bz',

title: '本周',

colspan:3

},{

align:'center',

valign:'middle',

field: 'by',

title: '本月',

colspan:3}],

[{

align:'center',

valign:'middle',

field: 'drbq',

title: '本期'

}, {

align:'center',

valign:'middle',

field: 'drtb',

title: '同比',

formatter:trend

},{

align:'center',

valign:'middle',

field: 'drhb',

title: '环比',

formatter:trend}, {

align:'center',

valign:'middle',

field: 'bzbq',

title: '本期'

}, {

align:'center',

valign:'middle',

field: 'bztb',

title: '同比',

formatter:trend

},{

align:'center',

valign:'middle',

field: 'bzhb',

title: '环比',

formatter:trend}, {

align:'center',

valign:'middle',

field: 'bybq',

title: '本期'

}, {

align:'center',

valign:'middle',

field: 'bytb',

title: '同比',

formatter:trend},{

align:'center',

valign:'middle',

field: 'byhb',

title: '环比',

formatter:trend

}]],

data:[{

id:1,

lhc:'来存量',

drbq:'21341',

drtb:'0.21',

drhb:'0.33',

bzbq:'35624',

bztb:'1.62',

bzhb:'3.16',

bybq:'42613',

bytb:'2.78',

byhb:'1.59'

},{

id:2,

lhc:'来存量',

drbq:'21341',

drtb:'0.21',

drhb:'0.33',

bzbq:'35624',

bztb:'1.62',

bzhb:'3.16',

bybq:'42613',

bytb:'2.78',

byhb:'1.59'

},{

id:3,

lhc:'来存量',

drbq:'21341',

drtb:'0.21',

drhb:'0.33',

bzbq:'35624',

bztb:'1.62',

bzhb:'3.16',

bybq:'42613',

bytb:'2.78',

byhb:'1.59'

},{

id:4,

lhc:'来存量',

drbq:'21341',

drtb:'0.21',

drhb:'0.33',

bzbq:'35624',

bztb:'1.62',

bzhb:'3.16',

bybq:'42613',

bytb:'2.78',

byhb:'1.59'

},{

id:5,

lhc:'来存量',

drbq:'21341',

drtb:'0.21',

drhb:'0.33',

bzbq:'35624',

bztb:'1.62',

bzhb:'3.16',

bybq:'42613',

bytb:'2.78',

byhb:'1.59'

},{

id:6,

lhc:'来存量',

drbq:'21341',

drtb:'0.21',

drhb:'0.33',

bzbq:'35624',

bztb:'1.62',

bzhb:'3.16',

bybq:'42613',

bytb:'2.78',

byhb:'1.59'

},{

id:7,

lhc:'来存量',

drbq:'21341',

drtb:'0.21',

drhb:'0.33',

bzbq:'35624',

bztb:'1.62',

bzhb:'3.16',

bybq:'42613',

bytb:'2.78',

byhb:'1.59'

},{

id:8,

lhc:'来存量',

drbq:'21341',

drtb:'0.21',

drhb:'0.33',

bzbq:'35624',

bztb:'1.62',

bzhb:'3.16',

bybq:'42613',

bytb:'2.78',

byhb:'1.59'

},{

id:9,

lhc:'来存量',

drbq:'21341',

drtb:'0.21',

drhb:'0.33',

bzbq:'35624',

bztb:'1.62',

bzhb:'3.16',

bybq:'42613',

bytb:'2.78',

byhb:'1.59'

},{

id:10,

lhc:'来存量',

drbq:'21341',

drtb:'0.21',

drhb:'0.33',

bzbq:'35624',

bztb:'1.62',

bzhb:'3.16',

bybq:'42613',

bytb:'2.78',

byhb:'1.59'

},{

id:11,

lhc:'来存量',

drbq:'21341',

drtb:'0.21',

drhb:'0.33',

bzbq:'35624',

bztb:'1.62',

bzhb:'3.16',

bybq:'42613',

bytb:'2.78',

byhb:'1.59'

},{

id:12,

lhc:'来存量',

drbq:'21341',

drtb:'0.21',

drhb:'0.33',

bzbq:'35624',

bztb:'1.62',

bzhb:'3.16',

bybq:'42613',

bytb:'2.78',

byhb:'1.59'

}]});

//模拟数据结束

//上下浮动箭头样式添加

function trend(value,row){

var trendIcon=row.id%2===0?'glyphicon glyphicon-arrow-down':'glyphicon glyphicon-arrow-up';

return " i>"+value

}

//表格插件一结束

分析:$('#tableL01').bootstrapTable({})是插件开始的标志,在其中添加表格的参数,然后在data:是表格的数据,而columns中则是设置列参数以及表格数据的地方,其中这个项目有代表性的是表头分为两部分,因此需要在columns中加两个数组【{}】,【{}】。之前都写在一个数组里,而源代码遍历的是columns的length

例二:

html相同都是只需要一个带id的table标签即可

js:

//表格插件(表二)开始

//声明用来统计合计(累计来煤,月计划)的变量

var yjhArr=[];

var ljlmArr=[];

$('#tableL02').bootstrapTable({

height:268,

//模拟数据

columns: [{

align:'center',

valign:'middle',

field: 'id',

title: '序号'

}, {

align:'center',

valign:'middle',

field: 'gys',

title: '供应商'

}, {

align:'center',

valign:'middle',

field: 'pz',

title: '品种'

},{

align:'center',

valign:'middle',

field: 'rz',

title: '热值'

},{

align:'center',

valign:'middle',

field: 'mj',

title: '煤价'

},{

align:'center',

valign:'middle',

field: 'bmdj',

title: '标煤单价'

},{

align:'center',

valign:'middle',

field: 'drlm',

title: '当日来煤'

},{

align:'center',

valign:'middle',

field: 'ljlm',

title: '累计来煤'

},{

align:'center',

valign:'middle',

field: 'yjhl',

title: '月计划量'

},{

align:'center',

valign:'middle',

field: 'yjhjd',

title: '月计划完成进度',

formatter:progress

}],

data:[{

id:2,

gys:'双欣矿业',

pz:'低硫煤',

rz:'',

mj:'',

bmdj:'',

drlm:'',

ljlm:'6686.08',

yjhl:'30000',

yjhjd:'22%'

},{

id:3,

gys:'伊泰股份',

pz:'工程煤',

rz:'',

mj:'',

bmdj:'',

drlm:'',

ljlm:'51888.72',

yjhl:'70000',

yjhjd:'74%'

},{

id:4,

gys:'嘉远公司',

pz:'中高硫煤',

rz:'',

mj:'',

bmdj:'',

drlm:'',

ljlm:'20041.86',

yjhl:'90000',

yjhjd:'100%'

},{

id:5,

gys:'爱地能源',

pz:'低硫煤',

rz:'',

mj:'',

bmdj:'',

drlm:'',

ljlm:'5191.08',

yjhl:'',

yjhjd:'0%'

},{

id:6,

gys:'恒泰煤炭',

pz:'中高硫煤',

rz:'',

mj:'',

bmdj:'',

drlm:'',

ljlm:'18265.56',

yjhl:'',

yjhjd:'0%'

},{

id:6,

gys:'恒泰煤炭',

pz:'中高硫煤',

rz:'',

mj:'',

bmdj:'',

drlm:'',

ljlm:'18265.56',

yjhl:'',

yjhjd:'0%'

},{

id:6,

gys:'恒泰煤炭',

pz:'中高硫煤',

rz:'',

mj:'',

bmdj:'',

drlm:'',

ljlm:'18265.56',

yjhl:'',

yjhjd:'0%'

}

]});

//模拟数据结束

//显示进度条的自定义列

function progress (value,row){

var width=parseInt(row.yjhjd);

var red='#e63737';

var blue='#b6ccf4';

yjhArr.push(row.yjhl);

ljlmArr.push(row.ljlm);

return "

"+value+"
"

if(yjhArr[i]==""){

yjhArr[i]=0;

}

subyjh+=parseFloat(yjhArr[i]);

}

for(var j=0;j

if(ljlmArr[j]==""){

ljlmArr[j]=0;

}

subljlm+=parseFloat(ljlmArr[j]);

}

row.push({

id:1,

gys:'合计',

pz:'',

rz:'',

mj:'',

bmdj:'',

drlm:'',

ljlm:subljlm.toFixed(2),

yjhl:subyjh,

yjhjd:'107%'

});

return row

}

分析:自定义行列需要添加data-formatter=‘方法名',其中progress()方法中的参数row,会在表格生成行的时候每生成一行就执行一次并将该行的对象传进来。

二:js方式

通过这种方法,可以很方便的为表格设置参数,处理数据方面十分便捷,尤其是设置请求方式和地址时,不过这个项目暂时只是静态页面,有关数据的以后接触在写上来

例一:同上例一

html:

if(ljlmArr[j]==""){

ljlmArr[j]=0;

}

subljlm+=parseFloat(ljlmArr[j]);

}

row.push({

id:1,

gys:'合计',

pz:'',

rz:'',

mj:'',

bmdj:'',

drlm:'',

ljlm:subljlm.toFixed(2),

yjhl:subyjh,

yjhjd:'107%'

});

return row

}

分析:自定义行列需要添加data-formatter=‘方法名',其中progress()方法中的参数row,会在表格生成行的时候每生成一行就执行一次并将该行的对象传进来。

二:js方式

通过这种方法,可以很方便的为表格设置参数,处理数据方面十分便捷,尤其是设置请求方式和地址时,不过这个项目暂时只是静态页面,有关数据的以后接触在写上来

例一:同上例一

html:

js:

//表格插件(表一)开始

$('#tableL01').bootstrapTable({

height:268,

//模拟数据

columns: [[{

GlGfxsMnKalign:'center',

valign:'middle',

field: 'lhc',

title: '来耗存',

rowspan:2

}, {

align:'center',

valign:'middle',

field: 'dr',

title: '当日',

colspan:3

}, {

align:'center',

valign:'middle',

field: 'bz',

title: '本周',

colspan:3

},{

align:'center',

valign:'middle',

field: 'by',

title: '本月',

colspan:3}],

[{

align:'center',

valign:'middle',

field: 'drbq',

title: '本期'

}, {

align:'center',

valign:'middle',

field: 'drtb',

title: '同比',

formatter:trend

},{

align:'center',

valign:'middle',

field: 'drhb',

title: '环比',

formatter:trend}, {

align:'center',

valign:'middle',

field: 'bzbq',

title: '本期'

}, {

align:'center',

valign:'middle',

field: 'bztb',

title: '同比',

formatter:trend

},{

align:'center',

valign:'middle',

field: 'bzhb',

title: '环比',

formatter:trend}, {

align:'center',

valign:'middle',

field: 'bybq',

title: '本期'

}, {

align:'center',

valign:'middle',

field: 'bytb',

title: '同比',

formatter:trend},{

align:'center',

valign:'middle',

field: 'byhb',

title: '环比',

formatter:trend

}]],

data:[{

id:1,

lhc:'来存量',

drbq:'21341',

drtb:'0.21',

drhb:'0.33',

bzbq:'35624',

bztb:'1.62',

bzhb:'3.16',

bybq:'42613',

bytb:'2.78',

byhb:'1.59'

},{

id:2,

lhc:'来存量',

drbq:'21341',

drtb:'0.21',

drhb:'0.33',

bzbq:'35624',

bztb:'1.62',

bzhb:'3.16',

bybq:'42613',

bytb:'2.78',

byhb:'1.59'

},{

id:3,

lhc:'来存量',

drbq:'21341',

drtb:'0.21',

drhb:'0.33',

bzbq:'35624',

bztb:'1.62',

bzhb:'3.16',

bybq:'42613',

bytb:'2.78',

byhb:'1.59'

},{

id:4,

lhc:'来存量',

drbq:'21341',

drtb:'0.21',

drhb:'0.33',

bzbq:'35624',

bztb:'1.62',

bzhb:'3.16',

bybq:'42613',

bytb:'2.78',

byhb:'1.59'

},{

id:5,

lhc:'来存量',

drbq:'21341',

drtb:'0.21',

drhb:'0.33',

bzbq:'35624',

bztb:'1.62',

bzhb:'3.16',

bybq:'42613',

bytb:'2.78',

byhb:'1.59'

},{

id:6,

lhc:'来存量',

drbq:'21341',

drtb:'0.21',

drhb:'0.33',

bzbq:'35624',

bztb:'1.62',

bzhb:'3.16',

bybq:'42613',

bytb:'2.78',

byhb:'1.59'

},{

id:7,

lhc:'来存量',

drbq:'21341',

drtb:'0.21',

drhb:'0.33',

bzbq:'35624',

bztb:'1.62',

bzhb:'3.16',

bybq:'42613',

bytb:'2.78',

byhb:'1.59'

},{

id:8,

lhc:'来存量',

drbq:'21341',

drtb:'0.21',

drhb:'0.33',

bzbq:'35624',

bztb:'1.62',

bzhb:'3.16',

bybq:'42613',

bytb:'2.78',

byhb:'1.59'

},{

id:9,

lhc:'来存量',

drbq:'21341',

drtb:'0.21',

drhb:'0.33',

bzbq:'35624',

bztb:'1.62',

bzhb:'3.16',

bybq:'42613',

bytb:'2.78',

byhb:'1.59'

},{

id:10,

lhc:'来存量',

drbq:'21341',

drtb:'0.21',

drhb:'0.33',

bzbq:'35624',

bztb:'1.62',

bzhb:'3.16',

bybq:'42613',

bytb:'2.78',

byhb:'1.59'

},{

id:11,

lhc:'来存量',

drbq:'21341',

drtb:'0.21',

drhb:'0.33',

bzbq:'35624',

bztb:'1.62',

bzhb:'3.16',

bybq:'42613',

bytb:'2.78',

byhb:'1.59'

},{

id:12,

lhc:'来存量',

drbq:'21341',

drtb:'0.21',

drhb:'0.33',

bzbq:'35624',

bztb:'1.62',

bzhb:'3.16',

bybq:'42613',

bytb:'2.78',

byhb:'1.59'

}]});

//模拟数据结束

//上下浮动箭头样式添加

function trend(value,row){

var trendIcon=row.id%2===0?'glyphicon glyphicon-arrow-down':'glyphicon glyphicon-arrow-up';

return " i>"+value

}

//表格插件一结束

分析:$('#tableL01').bootstrapTable({})是插件开始的标志,在其中添加表格的参数,然后在data:是表格的数据,而columns中则是设置列参数以及表格数据的地方,其中这个项目有代表性的是表头分为两部分,因此需要在columns中加两个数组【{}】,【{}】。之前都写在一个数组里,而源代码遍历的是columns的length

例二:

html相同都是只需要一个带id的table标签即可

js:

//表格插件(表二)开始

//声明用来统计合计(累计来煤,月计划)的变量

var yjhArr=[];

var ljlmArr=[];

$('#tableL02').bootstrapTable({

height:268,

//模拟数据

columns: [{

align:'center',

valign:'middle',

field: 'id',

title: '序号'

}, {

align:'center',

valign:'middle',

field: 'gys',

title: '供应商'

}, {

align:'center',

valign:'middle',

field: 'pz',

title: '品种'

},{

align:'center',

valign:'middle',

field: 'rz',

title: '热值'

},{

align:'center',

valign:'middle',

field: 'mj',

title: '煤价'

},{

align:'center',

valign:'middle',

field: 'bmdj',

title: '标煤单价'

},{

align:'center',

valign:'middle',

field: 'drlm',

title: '当日来煤'

},{

align:'center',

valign:'middle',

field: 'ljlm',

title: '累计来煤'

},{

align:'center',

valign:'middle',

field: 'yjhl',

title: '月计划量'

},{

align:'center',

valign:'middle',

field: 'yjhjd',

title: '月计划完成进度',

formatter:progress

}],

data:[{

id:2,

gys:'双欣矿业',

pz:'低硫煤',

rz:'',

mj:'',

bmdj:'',

drlm:'',

ljlm:'6686.08',

yjhl:'30000',

yjhjd:'22%'

},{

id:3,

gys:'伊泰股份',

pz:'工程煤',

rz:'',

mj:'',

bmdj:'',

drlm:'',

ljlm:'51888.72',

yjhl:'70000',

yjhjd:'74%'

},{

id:4,

gys:'嘉远公司',

pz:'中高硫煤',

rz:'',

mj:'',

bmdj:'',

drlm:'',

ljlm:'20041.86',

yjhl:'90000',

yjhjd:'100%'

},{

id:5,

gys:'爱地能源',

pz:'低硫煤',

rz:'',

mj:'',

bmdj:'',

drlm:'',

ljlm:'5191.08',

yjhl:'',

yjhjd:'0%'

},{

id:6,

gys:'恒泰煤炭',

pz:'中高硫煤',

rz:'',

mj:'',

bmdj:'',

drlm:'',

ljlm:'18265.56',

yjhl:'',

yjhjd:'0%'

},{

id:6,

gys:'恒泰煤炭',

pz:'中高硫煤',

rz:'',

mj:'',

bmdj:'',

drlm:'',

ljlm:'18265.56',

yjhl:'',

yjhjd:'0%'

},{

id:6,

gys:'恒泰煤炭',

pz:'中高硫煤',

rz:'',

mj:'',

bmdj:'',

drlm:'',

ljlm:'18265.56',

yjhl:'',

yjhjd:'0%'

}

]});

//模拟数据结束

//显示进度条的自定义列

function progress (value,row){

var width=parseInt(row.yjhjd);

var red='#e63737';

var blue='#b6ccf4';

yjhArr.push(row.yjhl);

ljlmArr.push(row.ljlm);

return "

}

//计算合计数值的方法

function yjhTotal(){

var subyjh=0;

var subljlm=0;

var row=[];

for(var i=0;i

if(yjhArr[i]==""){

yjhArr[i]=0;

}

subyjh+=parseFloat(yjhArr[i]);

}

for(var j=0;j

if(ljlmArr[j]==""){

ljlmArr[j]=0;

}

subljlm+=parseFloat(ljlmArr[j]);

}

row.push({

id:1,

gys:'合计',

pz:'',

rz:'',

mj:'',

bmdj:'',

drlm:'',

ljlm:subljlm,

yjhl:subyjh,

yjhjd:'107%'

});

return row

}

这个其实和第一种方式差别不大,只不过把自定义列放在数据中设置罢了。比较好理解。而关于其他参数可以参考官网,数据是动态的如何添加网上也有不少例子,只要都放在.bootstrapTable({})中就可以了

以上所述是给大家介绍的BootStrap table表格插件自适应固定表头(超好用),希望对大家有所帮助,如果大家有任何疑问请给我留言,会及时回复大家的。在此也非常感谢大家对我们网站的支持!

if(yjhArr[i]==""){

yjhArr[i]=0;

}

subyjh+=parseFloat(yjhArr[i]);

}

for(var j=0;j

if(ljlmArr[j]==""){

ljlmArr[j]=0;

}

subljlm+=parseFloat(ljlmArr[j]);

}

row.push({

id:1,

gys:'合计',

pz:'',

rz:'',

mj:'',

bmdj:'',

drlm:'',

ljlm:subljlm,

yjhl:subyjh,

yjhjd:'107%'

});

return row

}

这个其实和第一种方式差别不大,只不过把自定义列放在数据中设置罢了。比较好理解。而关于其他参数可以参考官网,数据是动态的如何添加网上也有不少例子,只要都放在.bootstrapTable({})中就可以了

以上所述是给大家介绍的BootStrap table表格插件自适应固定表头(超好用),希望对大家有所帮助,如果大家有任何疑问请给我留言,会及时回复大家的。在此也非常感谢大家对我们网站的支持!

if(ljlmArr[j]==""){

ljlmArr[j]=0;

}

subljlm+=parseFloat(ljlmArr[j]);

}

row.push({

id:1,

gys:'合计',

pz:'',

rz:'',

mj:'',

bmdj:'',

drlm:'',

ljlm:subljlm,

yjhl:subyjh,

yjhjd:'107%'

});

return row

}

这个其实和第一种方式差别不大,只不过把自定义列放在数据中设置罢了。比较好理解。而关于其他参数可以参考官网,数据是动态的如何添加网上也有不少例子,只要都放在.bootstrapTable({})中就可以了

以上所述是给大家介绍的BootStrap table表格插件自适应固定表头(超好用),希望对大家有所帮助,如果大家有任何疑问请给我留言,会及时回复大家的。在此也非常感谢大家对我们网站的支持!


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:input 禁止输入特殊字符的四种实现方式
下一篇:BootStrap iCheck插件全选与获取value值的解决方法
相关文章

 发表评论

暂时没有评论,来抢沙发吧~