您好,我在我的React JS项目中使用了Antd Treelect。当我单击父节点时,儿童选项不会出现

发布于 2025-01-27 09:17:11 字数 1735 浏览 1 评论 0原文

const treeData = [
  {
      title: '0-1',
      value: '0-1',
      key: '0-1',
   
  },
  {
    title: '0-2',
      value: '0-2',
      key: '0-2',
      children: [
          {
              title: '0-0-2',
              value: '0-0-2',
              key: '0-0-2',
          },
         
         
      ],
  },
  
  {
      title: '0-3',
      value: '0-3',
      key: '0-3',

  },
];

这是我的JSON数据,我将从API中获得。

 renderTreeNodes = data =>
    data.map(item => {
    
      if (item.children) {
        return (
         <TreeNode title={item.title} key={item.key} dataRef={item} isLeaf={false}>
          {this.renderTreeNodes(item.children)}
        </TreeNode>
        );
      }
      return <TreeNode key={item.key} {...item}  title={item.title} dataRef={item}  />;
    });


  render() {
    return (
      <Fragment>
      
        <TreeSelect
        treeCheckable={true}
        value={this.state.value}
                            className="treeSelect"
                            virtual={false}
                            style={{ width: 300 }}
                            treeCheckable
                            maxTagCount={20}
                            allowClear
                            showSearch
                            value={this.state.value}
                            closeMenuOnSelect={false}
                            placeholder="Please select SGC's"
                            allowClear
                            multiple
                            onChange={this.onChange} >{this.renderTreeNodes(treeData)}
                        </TreeSelect>
       
      </Fragment>
    );
  }
}
const treeData = [
  {
      title: '0-1',
      value: '0-1',
      key: '0-1',
   
  },
  {
    title: '0-2',
      value: '0-2',
      key: '0-2',
      children: [
          {
              title: '0-0-2',
              value: '0-0-2',
              key: '0-0-2',
          },
         
         
      ],
  },
  
  {
      title: '0-3',
      value: '0-3',
      key: '0-3',

  },
];

Here is my json data which i will get from api .

 renderTreeNodes = data =>
    data.map(item => {
    
      if (item.children) {
        return (
         <TreeNode title={item.title} key={item.key} dataRef={item} isLeaf={false}>
          {this.renderTreeNodes(item.children)}
        </TreeNode>
        );
      }
      return <TreeNode key={item.key} {...item}  title={item.title} dataRef={item}  />;
    });


  render() {
    return (
      <Fragment>
      
        <TreeSelect
        treeCheckable={true}
        value={this.state.value}
                            className="treeSelect"
                            virtual={false}
                            style={{ width: 300 }}
                            treeCheckable
                            maxTagCount={20}
                            allowClear
                            showSearch
                            value={this.state.value}
                            closeMenuOnSelect={false}
                            placeholder="Please select SGC's"
                            allowClear
                            multiple
                            onChange={this.onChange} >{this.renderTreeNodes(treeData)}
                        </TreeSelect>
       
      </Fragment>
    );
  }
}

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

月亮是我掰弯的 2025-02-03 09:17:11

我通过映射Treedata中的数据解决了这一问题。现在工作正常。

<TreeSelect
  treeCheckable={true}
  value={this.state.value}
  className="treeSelect"
  virtual={false}
  style={{ width: 300 }}
  treeCheckable
  maxTagCount={20}
  allowClear
  showSearch
  value={this.state.value}
  closeMenuOnSelect={false}
  placeholder="Please select SGC's"
  allowClear
  multiple
  treeData={treeData.map((d,i )  => ({
    title: d.title,
    value:  d.value,
    match: d.match,
    key: d.key,
    children: d.children                     
  }))}
  onChange={this.onChange}>
</TreeSelect>

I have resolved this by maping data inside treeData. working fine now.

<TreeSelect
  treeCheckable={true}
  value={this.state.value}
  className="treeSelect"
  virtual={false}
  style={{ width: 300 }}
  treeCheckable
  maxTagCount={20}
  allowClear
  showSearch
  value={this.state.value}
  closeMenuOnSelect={false}
  placeholder="Please select SGC's"
  allowClear
  multiple
  treeData={treeData.map((d,i )  => ({
    title: d.title,
    value:  d.value,
    match: d.match,
    key: d.key,
    children: d.children                     
  }))}
  onChange={this.onChange}>
</TreeSelect>
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文