el-tree结合checkbox实现数据回显

组件代码

javascript 复制代码
<el-tree
   :data="vertiList"
    show-checkbox
    node-key="id"
    :props="defaultProps"
    ref="treeRefx"
    class="custom-tree"
    @check-change="handleCheckChange"
    >
</el-tree>

获取选择的节点

javascript 复制代码
handleCheckChange(a,b,c){
          const selectedItems = this.$refs.treeRefx.getCheckedNodes(true);
          this.selectedValuex=selectedItems;
        },

初始值

javascript 复制代码
data(){
  return{
  		defaultProps: {
          children: 'children',
          label: 'label'
        },
        selectedValuex:[],
        vertiList:[{
          id: 1,
          label: '一级 1',
          children: [{
            id: 4,
            label: '二级 1-1',
            children: [{
              id: 9,
              label: '三级 1-1-1'
            }, {
              id: 10,
              label: '三级 1-1-2'
            }]
          }]
        }, {
          id: 2,
          label: '一级 2',
          children: [{
            id: 5,
            label: '二级 2-1'
          }, {
            id: 6,
            label: '二级 2-2'
          }]
        }, {
          id: 3,
          label: '一级 3',
          children: [{
            id: 7,
            label: '二级 3-1'
          }, {
            id: 8,
            label: '二级 3-2'
          }]
        }],
  }
}

checkbox数据回显方法

javascript 复制代码
reSetTree(){
    var xids=[];
    for(var i=0;i<this.selectedValuex.length;i++){
       xids.push(this.selectedValuex[i].id);
    }
    this.$nextTick(() => {
       this.$refs.treeRefx.setCheckedKeys(xids);
    });
 }
相关推荐
康一夏几秒前
Next.js 13变化有多大?
前端·react·nextjs
糖炒栗子03261 分钟前
前端项目标准环境搭建与启动
前端
不是az2 分钟前
CSS知识点记录
前端·javascript·css
爱分享的阿Q10 分钟前
GPT6-Spud-AGI前夜的豪赌
前端·easyui·agi
昵称暂无139 分钟前
.NET 高级开发 | i18n 原理、实现一个 i18n 框架
javascript·c#·.net
西西小飞龙40 分钟前
Less/Sass Mixins vs. Extend
前端·less·sass
syjy242 分钟前
(含下载)BeTheme WordPress主题使用教程
前端·wordpress·wordpress建站
Misnice1 小时前
shadcn如何使用
前端·reactjs
h_jQuery1 小时前
vue使用gm-crypto对数据进行sm4加密处理
前端·javascript·vue.js
阿赛工作室2 小时前
Vue中onBeforeUnmount不触发的解决方案
前端·javascript·vue.js