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

TreeSelect 禁止选中父级

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

实现效果:

未选中效果:

antd TreeSelect 禁止选中父级,只能选择子级_第1张图片

选中效果:

antd TreeSelect 禁止选中父级,只能选择子级_第2张图片

 

废话不多说,直接上代码

关键代码:

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

完整代码:

纯组件 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 (
          
            {renderTreeNodes(item.children)}
          
        );
      }
      return ;
    });
 
  return (
     onNodeChange(values)}
    >
      {renderTreeNodes(treeData)}
    
  );
};
 

调用:

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

转载地址:https://blog.csdn.net/savelifeme666/article/details/108619967

 

你可能感兴趣的:(react,antDesign,reactjs,javascript)