[vxe-table el-tree] 树表格:选中子节点,父节点无影响;选中父节点,子节点被选中,el-tree也同理

树表格:选中子节点,父节点无影响;选中父节点,子节点被选中,el-tree也同理

设置父子不关联,checkStrictly=true;

点击某个节点的多选框时,如果有子节点,递归设置子节点的checkbox选中/不选中

html 复制代码
<vxe-grid
  ref="xGrid"
  :data="tableData"
  :columns="columns"
  :tree-config="treeConfig"
  :checkbox-config="{ checkStrictly: true }"
  @checkbox-change="handleCheckboxChange"
/>
javascript 复制代码
tableData: [
   {
     id: 1,
     name: '父节点1',
     children: [
       { 
         id: 2, 
         name: '子节点1-1',
         children: [
           { id: 4, name: '孙节点1-1-1' }
         ]
       },
       { id: 3, name: '子节点1-2' }
     ]
   }
 ],
 treeConfig: {
   children: 'children',
   expandAll: true
 },
 columns: [
   { type: 'checkbox', width: 60, treeNode: true },
   { field: 'name', title: '名称' }
 ]
javascript 复制代码
handleCheckboxChange({ checked, row }) {
  // 如果有子节点,递归设置所有子孙节点
  if (row.children && row.children.length) {
    this.setAllChildren(row.children, checked)
  }
},

// 递归设置所有子节点
setAllChildren(children, checked) {
  const $table = this.$refs.xGrid
  children.forEach(child => {
    $table.setCheckboxRow(child, checked)
    if (child.children && child.children.length) {
      this.setAllChildren(child.children, checked)
    }
  })
}
相关推荐
小小小小宇4 分钟前
Harness Engineering 全解析与应用
前端
牧艺1 小时前
cos-design v3.0:从 15 个 Demo 到 49 个组件的视觉特效库
前端·视觉设计
lichenyang4531 小时前
ASCF 架构升级总览:WebRuntimePage 为什么要变薄
前端
道友可好1 小时前
从今天开始:你的第一个 Harness Engineering 实践
前端·人工智能·后端
Linsk1 小时前
组件 = 模板 + 业务逻辑
java·前端·vue.js
二月龙1 小时前
移动端 H5 页面开发:响应式适配 + 低版本兼容实战指南
前端
小强19881 小时前
HTML5 新表单全解:日期、手机号、颜色选择器
前端
妙码生花1 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(二):目录结构、初始化 GIT、设计并开发配置系统
前端·后端·go
鱼人2 小时前
HTML5 本地存储终极指南
前端
超绝大帅哥2 小时前
React的Fiber是什么? Vue为什么不需要Fiber ?
前端