vue elementui el-tree 设置父级不可选 子级只能单选

 

<el-tree 
  ref="tree" 
  :data="menuOptions" 
  show-checkbox 
  node-key="id" 
  check-strictly 
  empty-text="加载中,请稍候" 
  :props="defaultProps" 
  @check-change="handleCheckChange"
  >
</el-tree>
  data() {
    return {
      // 菜单列表
      menuOptions: [],     
      defaultProps: {
        children: "children",
        label: "label",
        disabled: function (data, node) {//带子级的节点不能选中
          if (data.children && data.children.length > 0) {
            return true
          } else {
            return false
          }
        }
      },      
    };
  },

  //在methods里
  handleCheckChange(data, checked){//子级只能单选
    if(checked){
      this.menuOptions.id = data.id
      this.$refs.tree.setCheckedKeys([data.id],true)
    }else{
      this.menuOptions.id = null
    }
  },

  • 3
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 7
    评论
在使用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 ]
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值