js 处理Tree结构,如果所有子节点disabled,则设置父节点也disabled

js 处理Tree结构,如果所有子节点disabled,则设置父节点也disabled

const treeData = {
    "key": "000",
    "title": "000",
    
    "children": [
        {
            "key": "100",
            "title": "100",
            
            "children": [
                {
                    "key": "110",
                    "title": "110",
                    
                    "children": [
                        {
                            "key": "111",
                            "title": "111",
                         
                            "disabled": true,
                            "children": []
                        }
                    ],
              
                    "disabled": false
                },
                {
                    "key": "120",
                    "title": "120)",
                    
                    "children": [
                        {
                            "key": "121",
                            "title": "121",
                     
                            "disabled": true,
                            "children": []
                        }
                    ],
               
                    "disabled": false
                }
            ]
            
        }
    ]
} 


const updateParentDisabledState = (node) => {
  // 如果所有子节点disabled,则设置父节点也disabled

  if (node.children && node.children.length > 0) {
    // 递归检查所有子节点的禁用状态
    node.children.forEach((child) => {
      updateParentDisabledState(child);
    });

    // 检查所有子节点是否都被禁用
    const allChildrenDisabled = node.children.every((child) => child.disabled);

    // 设置父节点的禁用状态
    node.disabled = allChildrenDisabled;
  }
};
updateParentDisabledState(treeData )
在使用el-tree组件时,想要让父节点不可选中,有几种方法可以实现。根据引用[2]中的代码,可以通过在props属性中设置disabled函数来判断是否为不可选父节点。具体的实现步骤如下: 1. 在props中添加一个自定义的disabled属性,设置为一个函数,函数接受两个参数data和node,分别表示当前节点的数据和节点对象。 2. 在disabled函数中,判断当前节点是否有子节点(通过data.children是否存在来判断),如果有子节点,则返回true,表示该节点不可选。 3. 否则,返回false,表示该节点可选。 以下是一个示例代码: ``` <el-tree :data="menuOptions" show-checkbox node-key="id" check-strictly :props="defaultProps"></el-tree> <script> export default { data() { return { menuOptions: [], // 菜单列表 defaultProps: { children: "children", label: "label", disabled: function (data, node) { if (data.children && data.children.length > 0) { return true; // 有子节点父节点不可选 } else { return false; // 没有子节点父节点可选 } }, }, }; }, }; </script> ``` 通过以上代码,父节点的可选性将根据其是否有子节点来决定。如果有子节点,则父节点不可选;如果没有子节点,则父节点可选。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [解决Jstree 选中父节点时被禁用子节点也会选中的问题](https://download.csdn.net/download/weixin_38705252/12960191)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [element tree单选 控制带有子级的父级不可选](https://blog.csdn.net/weixin_44741820/article/details/120518103)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [vue elementui el-tree 设置父级不可选 子级只能单选](https://blog.csdn.net/qq_27806371/article/details/131913420)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值