【antd受控树Tree组件】

1、效果

在这里插入图片描述

2、代码

import React, { useState } from "react";
import "./index.css";
import { Tree } from "antd";
import type { DataNode } from "antd/es/tree";

const treeData: DataNode[] = [
  {
    title: "0-0",
    key: "0-0",
    children: [
      {
        title: "0-0-0",
        key: "0-0-0",
        children: [
          {
            title: "0-0-0-0",
            key: "0-0-0-0",
            children: [
              { title: "0-0-0-0-1", key: "00--0-0-1" },
              { title: "0-0-0-0-2", key: "0-0-0-0-2" },
            ],
          },
          { title: "0-0-0-1", key: "0-0-0-1" },
          { title: "0-0-0-2", key: "0-0-0-2" },
        ],
      },
      {
        title: "0-0-1",
        key: "0-0-1",
        children: [
          { title: "0-0-1-0", key: "0-0-1-0" },
          { title: "0-0-1-1", key: "0-0-1-1" },
          { title: "0-0-1-2", key: "0-0-1-2" },
        ],
      },
      {
        title: "0-0-2",
        key: "0-0-2",
      },
    ],
  },
  {
    title: "0-1",
    key: "0-1",
    children: [
      { title: "0-1-0-0", key: "0-1-0-0" },
      { title: "0-1-0-1", key: "0-1-0-1" },
      { title: "0-1-0-2", key: "0-1-0-2" },
    ],
  },
  {
    title: "0-2",
    key: "0-2",
  },
];

const App: React.FC = () => {
  const [expandedKeys, setExpandedKeys] = useState<React.Key[]>([]);
  const [selectedKeys, setSelectedKeys] = useState<React.Key[]>([]);

  const onExpand = (expandedKeysValue: React.Key[], { node: { key } }) => {
    setExpandedKeys(expandedKeysValue);
    // 展开时,选中当前选项
    setSelectedKeys([key]);
  };

  // 选中与取消选中时,自动展开或收起当前折叠项
  const onSelect = (selectedKeysValue: React.Key[], { node: { key } }) => {
    setExpandedKeys((prevKeys) => {
      const newArr = new Set(expandedKeys);
      if (newArr.has(key)) {
        // 如果展开项已经有的话,就删掉
        newArr.delete(key);
      } else {
        // 没有的话,就加上
        newArr.add(key);
      }
      return [...newArr];
    });
    // 这里这样设置的话,就是点击谁,就一直选中谁
    setSelectedKeys([key]);
    // 这样设置的话,就是点击后,再次点击,会有取消选中的效果
    // setSelectedKeys(selectedKeysValue)
  };

  return (
    <Tree
      onExpand={onExpand}
      expandedKeys={expandedKeys}
      onSelect={onSelect}
      selectedKeys={selectedKeys}
      treeData={treeData}
    />
  );
};

export default App;

  • 11
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

呐呐呐呐。

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值