VUE递归树形实现多级列表


Posted in Vue.js onJuly 15, 2022

本文实例为大家分享了VUE递归树形实现多级列表,供大家参考,具体内容如下

什么是递归?

简单来说就是在组件中内使用组件本身。

为什么要用递归?

如果出现很多下拉菜单,同级,分级数据,层级混杂,可以使用v-for的嵌套循环不就完事了。对,没毛病这样的话也可以做,但是如果数据又多加了【很多】级分类呢;使用v-for也能实现,但是代码可能会比较杂或混乱!也不适合后期的维护,这个时候呢,我们就可以使用我们所说道的【递归组件 】了,使用递归组件,无论你的数据怎么增加我们都不用改动我们的代码。

先看效果:

VUE递归树形实现多级列表

1、创建两个文件

父组件tree.vue 子组件tree-detail

父组件代码:

<template>
    <div id="tree">
        <treedetail
       :title="list.name"    //把值传给子组件
       :list="list.children" //把值传给子组件
        :num='0'
        >
        </treedetail>
    </div>
</template>
<script>

/**
 * 模拟一个树形结构图
 */
const list = {
  name: "电子产品",
  children: [
    {
      name: "电视",
      children: [
        {
          name: "philips",
          children: [
            { name: "philips-A" },
            { name: "philips-B" },
            { name: "philips-C" }
          ]
        },
        {
          name: "Tcl",
          children: [
            { name: "Mac Air" },
            { name: "Mac Pro" },
            {
              name: "ThinlPad",
              children: [
                {
                  name: "ThinlPad-A",
                  children: [
                    { name: "ThinlPad-A-a" },
                    { name: "ThinlPad-A-b" },
                    { name: "ThinlPad-A-c" }
                  ]
                },
                { name: "ThinlPad-B" },
                { name: "ThinlPad-C" },
                { name: "ThinlPad-D" }
              ]
            }
          ]
        },
        { name: "海兴" }
      ]
    },
    {
      name: "电脑",
      children: [{ name: "acer" }, { name: "联想" }, { name: "惠普" }]
    },
    {
      name: "可穿戴的设备",
      children: [
        {
          name: "手环",
          children: [
            { name: "华为B5手环" },
            { name: "小米手环" },
            { name: "iphone手环" }
          ]
        }
      ]
    }
  ]
};
import treedetail from '../tree/treedetail' 
export default{
    name:'tree',
    data(){
        return{list}
    },
    components:{treedetail}  //注册子组件
}
</script>

子组件代码:

<template>
<div id="treedetail" >
    <div class="treedetail" @click="btn()" :style="indent">  //btn是用来切换显示隐藏
        <span>{{flag ? '-' :'+'}}</span> 
        <span>{{title}}</span> //接收到的标题
        </div>  
     <div  v-if="flag">  //这里加显示隐藏也是必要的
        <treedetail  //treedetail这里的命名要跟父组件注册子组件名称一样,不然无法显示。DIV就无法显示
        v-for="(item,index) in list" 
        :key="index"
        :title="item.name"
        :list='item.children'  //渲染列表下的列表数据
        :num='num + 1' //这里的作用应该是分清层级。
        ></treedetail>
    </div>   
  
    </div>
</template>
<script>
export default {
    name:'treedetail',
    props:{
        title:{
            type:String,
            default:'名称'
        },
        list:{type:Array},
        num:{
            type:Number,
            default:0
        }
    },
    data(){
        return{
            flag:false
        }
    },
    methods:{
        btn(){
            this.flag=!this.flag
        }
    },
    computed:{
        indent(){
            return `transform: translate(${this.num*20}px)`; 
        
            
        }
    }

}
</script>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Vue.js 相关文章推荐
Vue项目利用axios请求接口下载excel
Nov 17 Vue.js
详解Vue3 Teleport 的实践及原理
Dec 02 Vue.js
vue实现滚动鼠标滚轮切换页面
Dec 13 Vue.js
vue使用require.context实现动态注册路由
Dec 25 Vue.js
vue3+typeScript穿梭框的实现示例
Dec 29 Vue.js
梳理一下vue中的生命周期
Dec 30 Vue.js
vue3.0中友好使用antdv示例详解
Jan 05 Vue.js
Vue实现图书管理案例
Jan 20 Vue.js
深入了解Vue动态组件和异步组件
Jan 26 Vue.js
Vue ​v-model相关知识总结
Jan 28 Vue.js
Vue 事件的$event参数=事件的值案例
Jan 29 Vue.js
详解Vue的options
May 15 Vue.js
Vue2项目中对百度地图的封装使用详解
vue如何在data中引入图片的正确路径
Jun 05 #Vue.js
Vue Mint UI mt-swipe的使用方式
Jun 05 #Vue.js
vue @ ~ 相对路径 路径别名设置方式
Jun 05 #Vue.js
vue css 相对路径导入问题级踩坑记录
Jun 05 #Vue.js
vue中data里面的数据相互使用方式
Jun 05 #Vue.js
Vue 打包后相对路径的引用问题
Jun 05 #Vue.js
You might like
php str_pad 函数使用详解
2009/01/13 PHP
ThinkPHP3.2.2实现持久登录(记住我)功能的方法
2016/05/16 PHP
在textarea中屏蔽js的某个function的javascript代码
2007/04/20 Javascript
js String对象中常用方法小结(字符串操作)
2012/01/27 Javascript
Javascript的数组与字典用法与遍历对象的属性技巧
2012/11/07 Javascript
深入了解javascript中的prototype与继承
2013/04/14 Javascript
如何用JavaScript动态呼叫函数(两种方式)
2013/05/03 Javascript
枚举的实现求得1-1000所有出现1的数字并计算出现1的个数
2013/09/10 Javascript
jquery获得keycode的示例代码
2013/12/30 Javascript
thinkphp 表名 大小写 窍门
2015/02/01 Javascript
jquery实现滑动特效代码
2015/08/10 Javascript
原生JS实现仿淘宝网左侧商品分类菜单效果代码
2015/09/10 Javascript
深入探秘jquery瀑布流的实现
2016/01/30 Javascript
js和C# 时间日期格式转换的简单实例
2016/05/28 Javascript
浅谈JavaScript中变量和函数声明的提升
2016/08/09 Javascript
JS匿名函数实例分析
2016/11/26 Javascript
利用JQuery操作iframe父页面、子页面的元素和方法汇总
2017/09/10 jQuery
微信小程序使用toast消息对话框提示用户忘记输入用户名或密码功能【附源码下载】
2017/12/09 Javascript
手把手教你vue-cli单页到多页应用的方法
2018/05/31 Javascript
vue中的数据绑定原理的实现
2018/07/02 Javascript
create-react-app安装出错问题解决方法
2018/09/04 Javascript
nodejs中用npm初始化来创建package.json的实例讲解
2018/10/10 NodeJs
利用weixin-java-miniapp生成小程序码并直接返回图片文件流的方法
2019/03/29 Javascript
nodejs中request库使用HTTPS代理的方法
2019/04/30 NodeJs
微信小程序判断页面是否从其他页面返回的实例代码
2019/07/03 Javascript
node.js事件轮询机制原理知识点
2019/12/22 Javascript
原生js拖拽实现图形伸缩效果
2020/02/10 Javascript
Python零基础入门学习之输入与输出
2019/04/03 Python
Python3.5面向对象与继承图文实例详解
2019/04/24 Python
Philosophy美国官网:美国美容品牌
2016/08/15 全球购物
英语专业毕业生自荐信
2013/10/28 职场文书
应届生保险求职信
2013/11/11 职场文书
年终晚会主持词
2014/03/25 职场文书
募捐倡议书
2014/04/14 职场文书
廉洁自律演讲稿
2014/05/22 职场文书
离婚起诉书范本
2015/05/18 职场文书