Antd相关 Table表格自定义点击单元格(列)展开功能

起初参考网上其它写法,符号+失效需要隐藏,点击事件需要render实现,但是代码运行结果失败,点击没效果,研究API进行了改良……
改由单元格点击触发事件(不受render内容限制),且+号功能可同步使用(不用隐藏)

import React from "react";
import { Table } from "antd";

class TableEx extends React.Component {
  constructor(props) {
    super(props);
    this.state = { expandedRowKeys: [] };
  }

  expandRowByKey = (key) => {
    const { expandedRowKeys } = this.state;
    // const index = expandedRowKeys.findIndex((item) => key === item);
    // if (index > -1) expandedRowKeys.splice(index, 1);
    // else expandedRowKeys.push(key);
    // this.setState({ expandedRowKeys }); //注释部分是网上写法,运行并没有效果
    let keys = [...expandedRowKeys]; // 最后发现这的问题,坑了我半天时间
    if (index > -1) keys = keys.filter((item) => key !== item);
    else keys.push(key);
    this.setState({ expandedRowKeys: keys });
  };
  onExpand = (expanded, record) => {
    this.expandRowByKey(record.key);
  };

  render() {
    const { expandedRowKeys } = this.state;
    const columns = [
      { title: "Name", dataIndex: "name", key: "name" },
      { title: "Age", dataIndex: "age", key: "age" },
      { title: "Address", dataIndex: "address", key: "address" },
      {
        title: "Action",
        dataIndex: "",
        key: "x",
        render: () => <a>Expand</a>,
        onCell: (record) => {
          return {
            onClick: () => this.expandRowByKey(record.key),
          };
        },
      },
    ];
    const data = [
      {
        key: 1,
        name: "John Brown",
        age: 32,
        address: "New York No. 1 Lake Park",
        description:
          "My name is John Brown, I am 32 years old, living in New York No. 1 Lake Park.",
      },
      {
        key: 2,
        name: "Jim Green",
        age: 42,
        address: "London No. 1 Lake Park",
        description:
          "My name is Jim Green, I am 42 years old, living in London No. 1 Lake Park.",
      },
      {
        key: 3,
        name: "Not Expandable",
        age: 29,
        address: "Jiangsu No. 1 Lake Park",
        description: "This not expandable",
      },
      {
        key: 4,
        name: "Joe Black",
        age: 32,
        address: "Sidney No. 1 Lake Park",
        description:
          "My name is Joe Black, I am 32 years old, living in Sidney No. 1 Lake Park.",
      },
    ];
    console.log(expandedRowKeys);
    return (
      <Table
        columns={columns}
        expandable={{
          expandedRowKeys: expandedRowKeys,
          onExpand: this.onExpand,
          expandedRowRender: (record) => (
            <p style={{ margin: 0 }}>{record.description}</p>
          ),
        }}
        dataSource={data}
      />
    );
  }
}
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 如果您想在antd表格中同时满足两个合并条件,您可以使用`rowSpan`和`colSpan`属性进行操作。 例如,如果您想要合并一个单元并跨越两行和两,您可以将该单元的`rowSpan`和`colSpan`属性分别设置为2。 示例代码如下: ``` <Table> <TableBody> <TableRow> <TableCell rowSpan={2} colSpan={2}>合并的单元</TableCell> <TableCell>第一</TableCell> <TableCell>第二</TableCell> </TableRow> <TableRow> <TableCell>第一</TableCell> <TableCell>第二</TableCell> </TableRow> </TableBody> </Table> ``` 上述代码将创建一个包含合并单元和其他单元表格。合并单元将跨越两行和两,而其他单元将位于合并单元的下方和右侧。 您可以根据需要调整`rowSpan`和`colSpan`属性的值,以满足您的具体需求。 ### 回答2: 在 antd 表格中,要同时满足两个合并条件可以通过编写自定义的合并函数来实现。 首先,我们需要使用 `rowSpan` 和 `colSpan` 属性来合并单元。`rowSpan` 用于合并垂直方向上的单元,`colSpan` 用于合并水平方向上的单元。 然后,我们可以利用 `render` 属性中的回调函数,在渲染单元时动态地判断是否需要进行合并,并设置相应的合并属性。 下面是一个简单的示例代码,其中展示了如何同时满足两个合并条件: ```jsx import React from 'react'; import { Table } from 'antd'; const dataSource = [ { id: 1, name: 'A', age: 20, address: 'Address A', }, { id: 2, name: 'B', age: 20, address: 'Address B', }, { id: 3, name: 'B', age: 30, address: 'Address C', }, ]; const columns = [ { title: 'ID', dataIndex: 'id', key: 'id', render: (text, record, index) => { // 判断是否需要合并单元 if (index > 0 && record.name === dataSource[index - 1].name && record.age === dataSource[index - 1].age) { return { children: text, props: { rowSpan: 0, }, }; } return { children: text, props: {}, }; }, }, { title: 'Name', dataIndex: 'name', key: 'name', }, { title: 'Age', dataIndex: 'age', key: 'age', }, { title: 'Address', dataIndex: 'address', key: 'address', }, ]; const MyTable = () => <Table dataSource={dataSource} columns={columns} pagination={false} />; export default MyTable; ``` 在上述代码中,我们根据 `name` 和 `age` 字段的值判断是否需要合并单元。如果当前行的 `name` 和 `age` 与前一行的相同,即满足两个合并条件,则设置当前行的 `rowSpan` 属性为 0,使其不显示,同时将相同单元合并。 这是一个简单的实现示例,你可以根据具体需求和数据结构进行调整和扩展。 ### 回答3: antd表格单元合并是通过设置rowSpan和colSpan属性来实现的。如果要满足两个合并条件,可以同时设置合适的rowSpan和colSpan值。 比如说,我们有一个4x4的表格,要求将第一的前两行和第二的前两进行合并。我们可以这样设置表格单元的属性: ```jsx <Table> <TableBody> <TableRow> <TableCell rowSpan={2} colSpan={1}>合并单元</TableCell> <TableCell>单元</TableCell> <TableCell>单元</TableCell> <TableCell>单元</TableCell> </TableRow> <TableRow> <TableCell colSpan={2}>合并单元</TableCell> <TableCell>单元</TableCell> </TableRow> <TableRow> <TableCell>单元</TableCell> <TableCell>单元</TableCell> <TableCell>单元</TableCell> <TableCell>单元</TableCell> </TableRow> <TableRow> <TableCell>单元</TableCell> <TableCell>单元</TableCell> <TableCell>单元</TableCell> <TableCell>单元</TableCell> </TableRow> </TableBody> </Table> ``` 在这个例子中,我们通过设置第一的第一个单元的rowSpan为2,表示该单元要跨越两行。同时,我们设置第二的第一个单元的colSpan为2,表示该单元要跨越两。 这样,我们就成功地满足了两个合并条件,即第一的前两行和第二的前两进行了合并。 需要注意的是,具体的合并条件需要根据实际情况来设置,上述示例仅为演示。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值