2018-12-21 09:58:52 +08:00
|
|
|
|
/**
|
2019-03-20 17:44:05 +08:00
|
|
|
|
*
|
|
|
|
|
* @title 合并列后合计
|
|
|
|
|
* @description 合并标题后的合计,且支持多字段统计(通过使用的封装好的功能方法实现复杂功能,简单易用!)
|
|
|
|
|
*
|
|
|
|
|
*/
|
2018-12-21 09:58:52 +08:00
|
|
|
|
|
2019-03-20 17:44:05 +08:00
|
|
|
|
import React, { Component } from "react";
|
|
|
|
|
import {Button} from "tinper-bee";
|
|
|
|
|
import Table from "../../src";
|
|
|
|
|
import sum from "../../src/lib/sum.js";
|
|
|
|
|
|
|
|
|
|
let ComplexTable = sum(Table);
|
2018-12-21 09:58:52 +08:00
|
|
|
|
|
2019-03-20 17:44:05 +08:00
|
|
|
|
const columns = [
|
|
|
|
|
{
|
|
|
|
|
title: "Name",
|
|
|
|
|
dataIndex: "name",
|
|
|
|
|
key: "name",
|
|
|
|
|
width: 100,
|
|
|
|
|
fixed: "left"
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
title: "Other",
|
|
|
|
|
children: [
|
|
|
|
|
{
|
|
|
|
|
title: "Age",
|
|
|
|
|
dataIndex: "age",
|
|
|
|
|
key: "age",
|
|
|
|
|
width: 200,
|
|
|
|
|
sumCol: true,
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
title: "Address",
|
|
|
|
|
children: [
|
|
|
|
|
{
|
|
|
|
|
title: "Street",
|
|
|
|
|
dataIndex: "street",
|
|
|
|
|
key: "street",
|
|
|
|
|
width: 200
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
title: "Block",
|
|
|
|
|
children: [
|
|
|
|
|
{
|
|
|
|
|
title: "Building",
|
|
|
|
|
dataIndex: "building",
|
|
|
|
|
key: "building",
|
|
|
|
|
width: 100
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
title: "Door No.",
|
|
|
|
|
dataIndex: "number",
|
|
|
|
|
key: "number",
|
|
|
|
|
// width: 100,
|
|
|
|
|
sumCol: true,
|
|
|
|
|
}
|
|
|
|
|
]
|
|
|
|
|
}
|
|
|
|
|
]
|
|
|
|
|
}
|
|
|
|
|
]
|
|
|
|
|
},
|
|
|
|
|
// {
|
|
|
|
|
// title: "Company",
|
|
|
|
|
// children: [
|
|
|
|
|
// {
|
|
|
|
|
// title: "Company Address",
|
|
|
|
|
// dataIndex: "companyAddress",
|
|
|
|
|
// key: "companyAddress",
|
|
|
|
|
// width: 100,
|
|
|
|
|
// },
|
|
|
|
|
// {
|
|
|
|
|
// title: "Company Name",
|
|
|
|
|
// dataIndex: "companyName",
|
|
|
|
|
// key: "companyName",
|
|
|
|
|
// width: 100,
|
|
|
|
|
// }
|
|
|
|
|
// ]
|
|
|
|
|
// },
|
|
|
|
|
{
|
|
|
|
|
title: "Gender",
|
|
|
|
|
dataIndex: "gender",
|
|
|
|
|
key: "gender",
|
|
|
|
|
width: 80,
|
|
|
|
|
fixed: "right"
|
|
|
|
|
}
|
2018-12-21 09:58:52 +08:00
|
|
|
|
];
|
|
|
|
|
|
2019-03-20 17:44:05 +08:00
|
|
|
|
function getData(){
|
|
|
|
|
const data = [];
|
|
|
|
|
for (let i = 0; i < 5; i++) {
|
|
|
|
|
data.push({
|
|
|
|
|
key: i,
|
|
|
|
|
name: "John Brown"+i,
|
|
|
|
|
age: i + Math.floor(Math.random()*10),
|
|
|
|
|
street: "Lake Park",
|
|
|
|
|
building: "C",
|
|
|
|
|
number: 20 * Math.floor(Math.random()*10),
|
|
|
|
|
companyAddress: "Lake Street 42",
|
|
|
|
|
companyName: "SoftLake Co",
|
|
|
|
|
gender: "M"
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
return data;
|
|
|
|
|
}
|
2018-12-21 09:58:52 +08:00
|
|
|
|
|
2019-03-20 17:44:05 +08:00
|
|
|
|
class Demo18 extends Component {
|
|
|
|
|
|
2018-12-21 09:58:52 +08:00
|
|
|
|
constructor(props) {
|
|
|
|
|
super(props);
|
2019-03-20 17:44:05 +08:00
|
|
|
|
this.state = {
|
|
|
|
|
data: getData()
|
|
|
|
|
};
|
2018-12-21 09:58:52 +08:00
|
|
|
|
}
|
2019-03-20 17:44:05 +08:00
|
|
|
|
|
|
|
|
|
changeData = ()=>{
|
|
|
|
|
this.setState({
|
|
|
|
|
data: getData()
|
|
|
|
|
});
|
2018-12-21 09:58:52 +08:00
|
|
|
|
}
|
2019-03-20 17:44:05 +08:00
|
|
|
|
|
2018-12-21 09:58:52 +08:00
|
|
|
|
render() {
|
2019-03-20 17:44:05 +08:00
|
|
|
|
const {data} = this.state;
|
|
|
|
|
return (
|
|
|
|
|
<div>
|
|
|
|
|
<Button
|
|
|
|
|
className="editable-add-btn"
|
|
|
|
|
type="ghost"
|
|
|
|
|
onClick={this.changeData}
|
|
|
|
|
>
|
|
|
|
|
动态设置数据源
|
|
|
|
|
</Button>
|
|
|
|
|
|
|
|
|
|
<ComplexTable
|
|
|
|
|
columns={columns}
|
|
|
|
|
data={data}
|
|
|
|
|
bordered
|
|
|
|
|
// scroll={{ x: "130%", y: 140 }}
|
|
|
|
|
/>
|
|
|
|
|
</div>
|
|
|
|
|
);
|
2018-12-21 09:58:52 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
2019-03-20 17:44:05 +08:00
|
|
|
|
export default Demo18;
|