vue中el-tree动态初始默认选中和全选实现方法

 更新时间:2023年09月11日 09:05:25   作者:coinisi_li  
这篇文章主要给大家介绍了关于vue中el-tree动态初始默认选中和全选实现的相关资料,eltree默认选中eltree是一种常用的树形控件,通常用于在网页上呈现树形结构的数据,例如文件夹、目录、组织结构等,需要的朋友可以参考下

一、我们常用到element-ui组件中,Tree 树形控件。

官网链接:Element - The world's most popular Vue UI framework

二、实现效果如下图所示

涉及:1. 树结构转换一维数组 

           2. 与全选关联

           3. 父子组件间传值

<template>
  <div>
//全选选择框
    <el-checkbox
      v-model="checkAll"
      :indeterminate="isIndeterminate"
      @change="handleCheckAllChange"
    >
      全选
    </el-checkbox>
    <div style="margin: 15px 0" />
//可选择层级框
    <el-tree
      ref="tree"
      default-expand-all //是否默认展开所有节点 默认是false
      show-checkbox      //节点是否可被选择
      :data="menuOptions"
      node-key="id"      //每个树节点用来作为唯一标识的属性,整棵树应该是唯一的
      highlight-current
      //默认勾选的节点的 key 的数组,formmenu是从父组件拿到的值。在此组件中通过this.$refs.tree.getCheckedKeys();返回目前被选中的节点的 key 所组成的数组,传给formmenu。
      :default-checked-keys="formmenu"  
      :props="defaultProps"
    />
    <div style="margin: 15px 0" />
  </div>
</template>
<script>
import { getAllMenu } from '@/views/api/index';  //树数据接口
export default {
  props: {
    formmenu: {    //父组件传值子组件
      type: Array,
      default: () => {
        return [];
      },
    },
  },
  data() {
    return {
      checkAll: false,
      menuOptions: [],
      mydata: [],
      defaultProps: {
        children: 'children',
        label: 'menuName',
      },
      isIndeterminate: false,
    };
  },
  watch: {
    formmenu() {
      this.getTreeselect();
    },
  },
  created() {
    this.getTreeselect();
  },
  methods: {
    getTreeselect() {
      getAllMenu().then((response) => {
        this.menuOptions = response.data || []; //从接口拿到树数据
        this.$nextTick(() => {
          this.$refs.tree.setCheckedKeys(this.formmenu);  //通过 keys 设置目前勾选的节点,使用此方法必须设置 node-key 属性
          this.mydata = this.convertTreeData(this.menuOptions);//因为下面要判断数组长度,树的结构里包含children,所以要将其展开。
          //与全选关联起来,判断是否全部选中还是部分选中
          let checkedCount = this.formmenu.length;
          this.checkAll = checkedCount === this.mydata.length;
          this.isIndeterminate = 
      checkedCount > 0 && checkedCount < this.mydata.length;
        });
      });
    },
    // tree 结构转化成一维数组
    convertTreeData(menuOptions) {
      for (let i = 0; i < menuOptions.length; i++) {
        if (menuOptions[i].children != undefined) {
          const temp = menuOptions[i].children;
          delete menuOptions[i].children;
          menuOptions = menuOptions.concat(temp);
        }
      }
      return menuOptions;
    },
    handleCheckAllChange(val) {
      if (this.checkAll) {
        this.$refs.tree.setCheckedNodes(this.menuOptions);
      } else {
        this.$refs.tree.setCheckedKeys([]);
      }
      this.isIndeterminate = false;
    },
  },
};
</script>

三、关于key和node

大家可以参考官网文档,写的还是挺清楚的。

总结

到此这篇关于vue中el-tree动态初始默认选中和全选实现的文章就介绍到这了,更多相关el-tree动态初始默认选中全选内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 浅谈vue同一页面中拥有两个表单时,的验证问题

    浅谈vue同一页面中拥有两个表单时,的验证问题

    今天小编就为大家分享一篇浅谈vue同一页面中拥有两个表单时,的验证问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-09-09
  • vue 2.1.3 实时显示当前时间,每秒更新的方法

    vue 2.1.3 实时显示当前时间,每秒更新的方法

    今天小编就为大家分享一篇vue 2.1.3 实时显示当前时间,每秒更新的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-09-09
  • BuildAdmin elementPlus自定义表头添加tooltip方法示例

    BuildAdmin elementPlus自定义表头添加tooltip方法示例

    这篇文章主要介绍了BuildAdmin elementPlus 自定义表头,添加tooltip实现方法示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-09-09
  • vue3+vite+ts父子组件之间的传值

    vue3+vite+ts父子组件之间的传值

    随着vue2的落幕,vue3越来成熟,有必要更新一下vue3的父子组件之间的传值方式,这里介绍下vue3+vite+ts父子组件之间的传值方式实例详解,感兴趣的朋友一起看看吧
    2023-12-12
  • vue-router 中 meta的用法详解

    vue-router 中 meta的用法详解

    今天小编就为大家分享一篇vue-router 中 meta的用法详解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-11-11
  • Vue热更新出现内存溢出的解决方法

    Vue热更新出现内存溢出的解决方法

    开发项目有一段时间了,随着项目越来越大,打包的时间也相应的变长了,打包时的内存也增多了,这时候产生了一个问题,在发布项目的时候,会出现Vue热更新出现内存溢出的问题,所以本文给大家介绍了Vue热更新出现内存溢出的解决方法,需要的朋友可以参考下
    2024-05-05
  • vue、uniapp实现组件动态切换效果

    vue、uniapp实现组件动态切换效果

    在Vue中,通过使用动态组件,我们可以实现组件的动态切换,从而达到页面的动态展示效果,这篇文章主要介绍了vue、uniapp实现组件动态切换,需要的朋友可以参考下
    2023-10-10
  • 浅谈vue在html中出现{{}}的原因及解决方式

    浅谈vue在html中出现{{}}的原因及解决方式

    这篇文章主要介绍了浅谈vue在html中出现{{}}的原因及解决方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-11-11
  • vue实现定时刷新数据,每隔5分钟执行一次

    vue实现定时刷新数据,每隔5分钟执行一次

    这篇文章主要介绍了vue实现定时刷新数据,每隔5分钟执行一次问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-01-01
  • 在Vue中使用this.$store或者是$route一直报错的解决

    在Vue中使用this.$store或者是$route一直报错的解决

    今天小编就为大家分享一篇在Vue中使用this.$store或者是$route一直报错的解决,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-11-11

最新评论