132 lines
2.5 KiB
JavaScript
132 lines
2.5 KiB
JavaScript
/**
|
||
*
|
||
* @title 树型表格数据展示
|
||
* @parent 扩展行 Expanded Row
|
||
* @description 通过在data中配置children数据,来自动生成树形表格
|
||
*
|
||
*/
|
||
|
||
|
||
import React, { Component } from 'react';
|
||
import Table from '../../src';
|
||
|
||
|
||
const columns4 = [
|
||
{
|
||
title: "Name",
|
||
dataIndex: "name",
|
||
key: "name",
|
||
width: "40%"
|
||
},
|
||
{
|
||
title: "Age",
|
||
dataIndex: "age",
|
||
key: "age",
|
||
width: "30%"
|
||
},
|
||
{
|
||
title: "Address",
|
||
dataIndex: "address",
|
||
key: "address"
|
||
}
|
||
];
|
||
|
||
const data4 = [
|
||
{
|
||
key: 1,
|
||
name: "John Brown sr.",
|
||
age: 60,
|
||
address: "New York No. 1 Lake Park",
|
||
children: [
|
||
{
|
||
key: 11,
|
||
name: "John Brown",
|
||
age: 42,
|
||
address: "New York No. 2 Lake Park"
|
||
},
|
||
{
|
||
key: 12,
|
||
name: "John Brown jr.",
|
||
age: 30,
|
||
address: "New York No. 3 Lake Park",
|
||
children: [
|
||
{
|
||
key: 121,
|
||
name: "Jimmy Brown",
|
||
age: 16,
|
||
address: "New York No. 3 Lake Park"
|
||
}
|
||
]
|
||
},
|
||
{
|
||
key: 13,
|
||
name: "Jim Green sr.",
|
||
age: 72,
|
||
address: "London No. 1 Lake Park",
|
||
children: [
|
||
{
|
||
key: 131,
|
||
name: "Jim Green",
|
||
age: 42,
|
||
address: "London No. 2 Lake Park",
|
||
children: [
|
||
{
|
||
key: 1311,
|
||
name: "Jim Green jr.",
|
||
age: 25,
|
||
address: "London No. 3 Lake Park"
|
||
},
|
||
{
|
||
key: 1312,
|
||
name: "Jimmy Green sr.",
|
||
age: 18,
|
||
address: "London No. 4 Lake Park"
|
||
}
|
||
]
|
||
}
|
||
]
|
||
}
|
||
]
|
||
},
|
||
{
|
||
key: 2,
|
||
name: "Joe Black",
|
||
age: 32,
|
||
address: "Sidney No. 1 Lake Park"
|
||
}
|
||
];
|
||
class Demo4 extends Component {
|
||
|
||
constructor(props){
|
||
super(props);
|
||
this.state = {
|
||
data: data4,
|
||
factoryValue: 0,
|
||
selectedRow: new Array(data4.length)//状态同步
|
||
}
|
||
}
|
||
|
||
render() {
|
||
return <Table
|
||
rowClassName={(record,index,indent)=>{
|
||
if (this.state.selectedRow[index]) {
|
||
return 'selected';
|
||
} else {
|
||
return '';
|
||
}
|
||
}}
|
||
onRowClick={(record,index,indent)=>{
|
||
let selectedRow = new Array(this.state.data.length);
|
||
selectedRow[index] = true;
|
||
this.setState({
|
||
factoryValue: record,
|
||
selectedRow: selectedRow
|
||
});
|
||
}}
|
||
|
||
columns={columns4} data={data4} />;
|
||
}
|
||
}
|
||
|
||
|
||
export default Demo4; |