vue+antd 依据条件渲染table展开按钮

vue+antd自定义table展开按钮

<a-table
      :columns="columns"
      :data-source="data"
      :rowKey="(record) => record.id"
       :expandIcon="expandIcon"
    >
    </a-table>

最主要是这个expandIcon属性

在这里插入图片描述

    expandIcon(props) {
        //props.record是当前每行数据,(也可以依据每行数据的属性判断,如:props.record.id,props.record.key等等,这个依据自己的需求字段属性)
        
        //复制的兄弟需要把props.record.leafTag改为自己的属性!!!!!!这个很重要
        
        if (props.record.leafTag) {
        //props.expanded当前行状态 展开为true,收起为false.
        //有兴趣的可以把props全部打印出来看下
          if (props.expanded) {//有数据-展开时候图标
            return (
              <a
                style="color: black;"
                onClick={(e) => {
                  props.onExpand(props.record, e);
                }}
              >
                <a-icon type="minus-square" />{" "}
              </a>
            );
          } else {//有数据-未展开时候图标
            return (
              <a
                style="color: black;"
                onClick={(e) => {
                  props.onExpand(props.record, e);
                }}
              >
                <a-icon type="plus-square" />
              </a>
            );
          }
        } else {//无数据-图标
        //这里我选择的是没有的话就不渲染
          return (
            <span></span>
          );
        }
    },

效果图

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值