Table 没有在 Reactjs 中相应地显示数据

Table is not showing data accordingly in Reactjs

我正在尝试将 API 的响应显示到 react-semantic-ui table。使用获取数据设置状态后,我需要将 first-order 键作为列名,然后将 second-order 键作为行名,然后将显示 second-order 键的值在 table-body。我已经做到了这一点,这导致每行中的单元格数量加倍,同时使用相同的数据设置所有单元格值。

class NonProtectedFeatureBias extends Component {
    constructor(props){
        super(props);
        this.state = {       
            staticPostData:{
                dataset_id: 1
            },
            tableData:{},
            tableColumnNames:[],
        };
    }
    renderKeys (data) {
        let tcolumn = [];
        for(let i=0; i<Object.keys(data).length;i++){
            const Obj1 = Object.keys(data)[i];
            //console.log(Obj1)
            tcolumn.push(Obj1);

        }
        let col = tcolumn.map(item=>{
            return <Table.HeaderCell>{item}</Table.HeaderCell>
        })
        return col
    }
    renderValues (data) {
        let row=null;
        for(let i=0; i<Object.keys(data).length;i++){
            const Obj1 = Object.values(data)[i];

            let trows = [];
            const Obj2 = Object.keys(Obj1).map(item =>{
                trows.push(item);
            });

            let tvalues =[];
            const Obj3 = Object.values(Obj1).map(item =>{
                tvalues.push(item);
                console.log(item)
            });
            row = trows.map(item=>{
                return(
                    <Table.Row  className="cell-current">
                        <Table.Cell className="cell-width-single">{item}</Table.Cell>
                        {tvalues.map(val =>{
                            return <Table.Cell selectable>{val}</Table.Cell>
                            //console.log(val)
                        })}
                    </Table.Row>
                )
            })
        }

        return row
    }

    componentDidMount() {
        this.fetchData();
    }
    fetchData(){
        axios.post('http://localhost:5000/GetProxyTable', this.state.staticPostData)
         .then((response) =>{

            var count = Object.keys(response.data).length;
            this.setState({tableData:response.data})
            console.log(response.data)
        });
    }
    render(){
        return ( 
            <Container style={{height:"250px", backgroundColor:""}}>
                <Table definition >
                    <Table.Header>
                    <Table.Row className="cell-with-no-padding">
                        <Table.HeaderCell />
                        {this.renderKeys(this.state.tableData)}
                    </Table.Row>
                    </Table.Header>

                    <Table.Body>
                        {this.renderValues(this.state.tableData)}
                    </Table.Body>
                </Table>
            </Container>
        );
    }
}
export default NonProtectedFeatureBias;

这是我从 API

得到的回复

这就是我想要实现的,

这就是我现在得到的,

这是实现我目标的正确方法吗?!我希望有一个 much-optimized 的方法来做到这一点。而且我还需要能够单击一个单元格并获取相关的行和列名称。任何建议或意见将不胜感激。

您的 renderValues 正在通过列而不是行进行映射。另外,您将每个假行设置为相同的值,因此所有 'rows' 都相等。最后,returns 最后一个,这意味着最后一列值。

您可以尝试下面的代码,在呈现行之前先将列映射到行对象:

renderValues (data) {
  const rows = {}
  Object.values(data).forEach(col => {
    for (let [key, value] of Object.entries(col)) {
      rows[key] = rows[key] ? [...rows[key], value] : [value]
    }
  })

  return Object.entries(rows).map(([item, values]) => (
    <Table.Row className="cell-current">
      <Table.Cell className="cell-width-single">{item}</Table.Cell>
        { values.map(val => <Table.Cell selectable>{val}</Table.Cell> ) }
    </Table.Row>
  ))
}