react antd TreeSelect实现自定义标签

javascript 复制代码
 <ProFormTreeSelect
                label="接收对象"
                name="receiverObjects"
                colProps={{ span: 16 }}
                labelCol={{
                  span: 6,
                }}
                wrapperCol={{
                  span: 18,
                }}
                rules={[{ required: true }]}
                fieldProps={{
                  showSearch: true,
                  multiple: true,
                  // autoClearSearchValue: true,
                  filterTreeNode: true,
                  treeCheckable: true,
                  treeDataSimpleMode: true,
                  treeNodeFilterProp: 'label',
                  tagRender: (props) => {
                    if (!props.value) return <></>;
                    const ReceiverType = props.value.split('_')[0];
                    let selectTreeData = groupTree;
                    switch (ReceiverType) {
                      case 'group': {
                        selectTreeData = groupTree;
                        break;
                      }
                      case 'user': {
                        selectTreeData = userTree;
                        break;
                      }
                      case 'location': {
                        selectTreeData = locationTree;
                        break;
                      }
                      default:
                        break;
                    }
                    const selectObj = getTreeLabel(selectTreeData, props.value);
                  
                    return (
                      <div className="ant-select-selection-overflow">
                        <div className="ant-select-selection-overflow-item">
                          <span className="ant-select-selection-item" title={selectObj?.label}>
                            <span className="ant-select-selection-item-content">
                              {selectObj?.label}
                            </span>
                            <span
                              className="ant-select-selection-item-remove"
                              onClick={() => {
                                props.onClose();
                              }}
                            >
                              <span className="anticon anticon-close">
                                <CloseOutlined />
                              </span>
                            </span>
                          </span>
                        </div>
                      </div>
                    );
                  },

                  dropdownRender: (originNode: ReactNode) => {
                    return (
                      <div>
                        <Tabs
                          type="line"
                          className="w-full pl-4"
                          activeKey={activeKey}
                          tabBarStyle={{ height: '32px', marginBottom: '4px' }}
                          onChange={(activeKey) => {
                            setActiveKey(activeKey);
                          }}
                          items={ReceiverType}
                        />
                        {originNode}
                      </div>
                    );
                  },
                  treeData: treeData,
                }}
              />

selectObj的值是:(单个选项)

tagRender:显示的是单个tag的数据

|------------------|-----------------------|
| 自定义 tag 内容,多选时生效 | (props) => ReactNode |

复制代码
  const getTreeLabel = (data: TreeProps, value: string) => {
    let result: TreeItemProps = {};
    let fn = function (data: TreeProps) {
      if (Array.isArray(data)) {
        for (let i = 0; i < data.length; i++) {
          const e = data[i];
          if (e.key === value) {
            result = e; // 返回的结果等于每一项
            break;
          } else if (e.children) {
            fn(e.children); // 递归调用下边的子项
          }
        }
      }
    };
    fn(data); // 调用一下
    return result;
  };
相关推荐
倾颜2 小时前
从 textarea 到 AI 输入框:用 Tiptap 实现 / 命令、@ 引用和结构化请求
前端·langchain·next.js
kyriewen4 小时前
程序员连夜带团队跑路,省了23万:这AI太贵,真的用不起了
前端·javascript·openai
kyriewen4 小时前
你写的代码没有测试,就像出门不锁门——Jest + Testing Library 从入门到不慌
前端·单元测试·jest
yuzhiboyouye5 小时前
web前端英语面试
前端·面试·状态模式
canonical_entropy6 小时前
下一代低代码渲染框架 nop-chaos-flux 的设计原则
前端·低代码·前端框架
东方小月6 小时前
5分钟搞懂Harness Engineering(驾驭工程):从提示词到AI Agent的进化之路
前端·后端·架构
我叫黑大帅6 小时前
为什么需要 @types/react?解决“无法找到模块 react 的声明文件”报错
前端·javascript·面试
之歆7 小时前
DAY_21JavaScript 深度解析:数组(Array)与函数(Function)(一)
前端·javascript
XinZong7 小时前
【AI社交】基于OpenClaw自研轻量化AI社交平台实战
前端
Le_ee8 小时前
ctfweb:php/php短标签/.haccess+图片马/XXE
开发语言·前端·php