el-tree默认选中某个数据

本文详细讲解了如何在Vue应用中使用el-tree组件,包括如何设置初始选中项和响应节点点击事件,适合前端开发者参考。
<template>
  <div class="page">
    <el-tree
      highlight-current
      node-key="label"
      :data="data"
      ref="tree"
      :props="defaultProps"
      @node-click="handleNodeClick"
    ></el-tree>
  </div>
</template>

<script>

export default {
  name: 'page',
  data () {
    return {
    //,想要默认选中的项
      curren: '', //传入节点id
      data: [{
        label: '一级 1',
        children: [{
          label: '1111',
          children: [{
            label: '三级 1-1-1'
          }]
        }]
      }, {
        label: '一级 2',
        children: [{
          label: '二级 2-1',
          children: [{
            label: '三级 2-1-1'
          }]
        }, {
          label: '二级 2-2',
          children: [{
            label: '三级 2-2-1'
          }]
        }]
      }, {
        label: '一级 3',
        children: [{
          label: '二级 3-1',
          children: [{
            label: '三级 3-1-1'
          }]
        }, {
          label: '二级 3-2',
          children: [{
            label: '三级 3-2-1'
          }]
        }]
      }],
      defaultProps: {
        children: 'children',
        label: 'label'
      }
    }
  },
  mounted () {
  //方式一: 调用方法 来渲染默认项
    this.fetchTreeData()
  },
  methods: {
    handleNodeClick (data) {
      console.log(data)
    },
    fetchTreeData () {
    // 在 el-tree中 定义ref 来选中el-tree 调用setCurrentKey方法 
    //如果设置node-key="id"  this.curren应传入节点id
    // 把想要高亮选中的项传入 
      this.$refs.tree.setCurrentKey(this.curren)
    }
  }

}
</script>

要在`el-tree`组件中默认选中节点,可通过`default-checked-keys`属性或使用`setCheckedKeys`方法来实现。 ### 方法一:使用`default-checked-keys`属性 在`el-tree`组件上绑定`default-checked-keys`属性,该属性接收一个数组,数组中的元素为要默认选中节点的`key`值。示例代码如下: ```vue <template> <el-tree :data="treeData" :props="defaultProps" show-checkbox :default-checked-keys="[2]" > </el-tree> </template> <script> export default { data() { return { treeData: [ { id: 1, label: '一级 1', children: [ { id: 2, label: '二级 1-1', children: [ { id: 3, label: '三级 1-1-1' } ] } ] } ], defaultProps: { children: 'children', label: 'label' } }; } }; </script> ``` 在上述代码中,`default-checked-keys`属性的值为`[2]`,表示默认选中`id`为`2`的节点。 ### 方法二:使用`setCheckedKeys`方法 在组件挂载后,通过`$refs`获取`el-tree`实例,然后调用`setCheckedKeys`方法来设置默认选中的节点。示例代码如下: ```vue <template> <el-tree ref="treeRef" :data="treeData" :props="defaultProps" show-checkbox > </el-tree> </template> <script> export default { data() { return { treeData: [ { id: 1, label: '一级 1', children: [ { id: 2, label: '二级 1-1', children: [ { id: 3, label: '三级 1-1-1' } ] } ] } ], defaultProps: { children: 'children', label: 'label' } }; }, mounted() { this.$nextTick(() => { this.$refs.treeRef.setCheckedKeys([2]); }); } }; </script> ``` 在上述代码中,在`mounted`钩子函数中,使用`$nextTick`确保`el-tree`组件已经渲染完成,然后通过`$refs`获取`el-tree`实例,并调用`setCheckedKeys`方法,传入要默认选中节点的`id`数组`[2]`。
评论 2
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值