antd TreeSelect 禁止选中父级,只能选择子级

2 篇文章 0 订阅
1 篇文章 0 订阅

TreeSelect 禁止选中父级

需求:只能选中子级,不能不能选择

实现效果:
未选中效果选中效果

废话不多说,直接上代码

关键代码:

const renderTreeNodes = data =>
    data.map(item => {
      if (item.children) {
        // 这一句是关键代码,设置父级都为禁用模式,有条件的让后台返回
        item.disabled = true;
        return (
          <TreeNode
            key={item.key}
            title={item.label}
            value={item.value}
            disabled={item.disabled}
          >
            {renderTreeNodes(item.children)}
          </TreeNode>
        );
      }
      return <TreeNode {...item} key={item.key} title={item.label} value={item.value} />;
    });

完整代码:

纯组件 TreeNodeSelect

import React from 'react';
import { TreeSelect } from 'antd';

const { TreeNode } = TreeSelect;

export default ({ treeData = [], onChange, value = [], placeholder = '请选择消息提醒人' }) => {
  const onNodeChange = values => {
    console.log('val', values);
    onChange(values);
  };

  const renderTreeNodes = data =>
    data.map(item => {
      if (item.children) {
        item.disabled = true;
        return (
          <TreeNode key={item.key} title={item.label} value={item.value} disabled={item.disabled}>
            {renderTreeNodes(item.children)}
          </TreeNode>
        );
      }
      return <TreeNode {...item} key={item.key} title={item.label} value={item.value} />;
    });

  return (
    <TreeSelect
      showSearch
      style={{ width: '100%' }}
      value={value}
      dropdownStyle={{ maxHeight: 400, overflow: 'auto' }}
      placeholder={placeholder}
      treeNodeFilterProp="label"
      allowClear
      multiple
      treeDefaultExpandAll
      onChange={values => onNodeChange(values)}
    >
      {renderTreeNodes(treeData)}
    </TreeSelect>
  );
};

调用:


const treeData = [
  {
    key: 10,
    value: 10,
    label: '项目部',
    children: [
      {
        key: 84,
        value: 100084,
        label: '伍',
      },
      {
        key: 83,
        value: 100083,
        label: '黄',
      },
      {
        key: 85,
        value: 100085,
        label: '樊',
      },
    ],
  },
];


<TreeNodeSelect treeData={treeData} onChange={onChange} value={value}>

如果有写错的地方请指正!蟹蟹啦!

  • 5
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 15
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值