Vue实现树形视图数据步骤详解

这次给大家带来Vue实现树形视图数据步骤详解,Vue实现树形视图数据的注意事项有哪些,下面就是实战案例,一起来看一下。

这是模拟的树形图数据

let all={   name:'all',   children:{    A:{     name:'A',     children:{      a1:{       name:'a1',       children:{        a11:{          name:'a11',         children:null        },        a12:{          name:'a12',         children:null        }       }      },      a2:{       name:'a2',       children:{        b21:{          name:'b21',         children:null        }       }      }     }    },    B:{     name:'B',     children:{      b1:{       name:'b1',       children:{        b11:{          name:'b11',         children:null        },        b12:{          name:'b12',         children:null        }       }      },      b2:{       name:'b2',       children:{        b21:{          name:'b21',         children:null        }       }      }     }    }   }  }

登录后复制

代码如下

treelist.vue

 

  • {{treelist.name}}

export default { name:'tree', props:['treelist'], data(){ return{ open:false } },computed:{ isFolder:function(){ return this.treelist.children } } ,methods:{ isshow(){ if (this.isFolder) { this.open =!this.open } } } }

登录后复制

index.html

          树形图    

登录后复制

index.js

import Vue from 'vue'; import tree from '../components/treelist.vue' let all={   name:'all',   children:{    A:{     name:'A',     children:{      a1:{       name:'a1',       children:{        a11:{          name:'a11',         children:null        },        a12:{          name:'a12',         children:null        }       }      },      a2:{       name:'a2',       children:{        b21:{          name:'b21',         children:null        }       }      }     }    },    B:{     name:'B',     children:{      b1:{       name:'b1',       children:{        b11:{          name:'b11',         children:null        },        b12:{          name:'b12',         children:null        }       }      },      b2:{       name:'b2',       children:{        b21:{          name:'b21',         children:null        }       }      }     }    }   }  } const app=new Vue({  el:"#app",  components:{   'tree':tree  },  data:{   treeList:all  } })

登录后复制

在经过踩坑之后,我发现Vue官网有类似的案例,链接→ 传送门

参考过官网的方法后,我尝试着实现了一下

这样写和我踩坑时的 思路不同点在于, 这样一个组件只负责一个 对象,遍历每个children 中的对象,逐个传入组件处理,而我第一次尝试则是 将整个children  传入自身   是一个组件处理多个对象,(第一次尝试的失败案例,有兴趣请看最下方)

这样一个组件处理一个对象 写的好处是什么呢

我可以在组件内自定义开关了

我在data里定义了变量open,因为组件递归,所以相当于每个组件都有个属于自己的open

Vue实现树形视图数据步骤详解

那为什么第一次踩坑时我不可以用这种方法呢,因为我第一次尝试 是一个组件处理多个对象 就是相当于 一个开关控制 children中的所有对象,当开关打开时会导致 这个同级的所有 对象都被展开

遍历children 挨个传入组件自身    用v-show 来控制是否显示 

Vue实现树形视图数据步骤详解

定义了一个计算属性,依据children来判断是否继续执行 

Vue实现树形视图数据步骤详解

在span标签上绑定了一个自定义事件

更改open 的值 

{{treelist.name}}

登录后复制

Vue实现树形视图数据步骤详解

实现效果

Vue实现树形视图数据步骤详解

以下 是我刚开始尝试的时候踩得坑

在这里记录一下,以后遇到类似问题留个印象

首先上来就遇到了这样的报错

Vue实现树形视图数据步骤详解

找了很久的问题,发现是因为组件内忘记写name了,自身使用自身必须填写name,并且与标签名一致

Vue实现树形视图数据步骤详解

一开始的实现方法,利用组件递归,显示出当前级的name渲染出来,并将其中的 children 中的所有对象 传给自己然后接着执行相同操作,直到children没有数据,值得一提的是

Vue实现树形视图数据步骤详解

,如果这里不加上 v-if 就会变成 死循环,就会一直执行下去,所以我们要判断一下当前执行的对象到底还有没有下一级

Vue实现树形视图数据步骤详解

这里我数据有稍微的改动,所以我第一次传入的数据就是(index.html页面)

Vue实现树形视图数据步骤详解

然后我定义了一个事件来处理 每一层的关闭和开启,我用弹框来查看Isopen 的值是否被改变

Vue实现树形视图数据步骤详解

我们看一下结果

刚进入页面时,括号中的undefined是 Isopen 当前的值,因为此时未被定义,所以为undefined

Vue实现树形视图数据步骤详解

然后我点击了A

Vue实现树形视图数据步骤详解

因为此时isopen已被反转值,所以此时isopen为true

Vue实现树形视图数据步骤详解

但是页面仍毫无变化,不说展开功能,就连undefined也没变化

Vue实现树形视图数据步骤详解

经过一番百度 ,发现原来是vue本身已经不允许这样直接更改 Props接受过来的值了

相信看了本文案例你已经掌握了方法,更多精彩请关注【创想鸟】其它相关文章!

推荐阅读:

JS DOM元素常见增删改查操作详解

JS callback回调函数使用案例详解

以上就是Vue实现树形视图数据步骤详解的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2762310.html

(0)
上一篇 2025年3月8日 09:54:16
下一篇 2025年3月8日 09:54:44

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • React Form组件封装步骤详解

    这次给大家带来React Form组件封装步骤详解,React Form组件封装的注意事项有哪些,下面就是实战案例,一起来看一下。 前言 对于网页系统来说,表单提交是一种很常见的与用户交互的方式,比如提交订单的时候,需要输入收件人、手机号、…

    2025年3月8日
    200
  • 把v-for中表格导出步骤详解

    这次给大家带来把v-for中表格导出步骤详解,v-for中表格导出的注意事项有哪些,下面就是实战案例,一起来看一下。 一、需要安装以下依赖 npm install -S file-saver xlsx npm install -D scri…

    编程技术 2025年3月8日
    200
  • Node.js+Koa实现JWT用户认证步骤详解

    这次给大家带来Node.js+Koa实现JWT用户认证步骤详解,Node.js+Koa实现JWT用户认证的注意事项有哪些,下面就是实战案例,一起来看一下。 一、前置知识 基于Token的身份验证 Koajs 中文文档 Koa 框架教程 二、…

    2025年3月8日 编程技术
    200
  • Vue父子组件数据传递方法总结(附代码)

    这次给大家带来Vue父子组件数据传递方法总结(附代码),Vue父子组件数据传递方法总结的注意事项有哪些,下面就是实战案例,一起来看一下。 当我们在书写 vue 组件的时候,也许可能会用到数据传递;将父组件的数据传递给子组件,有时候也需要通过…

    2025年3月8日 编程技术
    200
  • vue地区选择组件使用步骤详解

    这次给大家带来vue地区选择组件使用步骤详解,vue地区选择组件使用的注意事项有哪些,下面就是实战案例,一起来看一下。 概述 主要用于全国地区数据的操作,包括省,市,区三级联动,地区数据的添加和删除; 在操作地区数据时,以前也用过树形的地区…

    编程技术 2025年3月8日
    200
  • vue mint-ui tabbar组件使用步骤详解

    这次给大家带来vue mint-ui tabbar组件使用步骤详解,vue mint-ui tabbar组件使用的注意事项有哪些,下面就是实战案例,一起来看一下。 新建tabbar.vue 主页 积分商城 微社区 我的 export def…

    编程技术 2025年3月8日
    200
  • Vue内引入tinymce富文本编辑器步骤详解

    这次给大家带来Vue内引入tinymce富文本编辑器步骤详解,Vue内引入tinymce富文本编辑器的注意事项有哪些,下面就是实战案例,一起来看一下。 项目中原本使用的富文本编辑器是 wangEditor,这是一个很轻量、简洁编辑器 但是公…

    2025年3月8日 编程技术
    200
  • Vue.js双向绑定实现步骤说明

    这次给大家带来Vue.js双向绑定实现步骤说明,Vue.js双向绑定实现的注意事项有哪些,下面就是实战案例,一起来看一下。 这篇体验一下VUE的双向绑定 当前时刻{{ CurrentTime }} var app = new Vue({ e…

    2025年3月8日
    200
  • Vue+canvas实现移动端手写板步骤详解

    这次给大家带来Vue+canvas实现移动端手写板步骤详解,Vue+canvas实现移动端手写板的注意事项有哪些,下面就是实战案例,一起来看一下。 清除 保存 Canvas画板 var draw;var preHandler = funct…

    编程技术 2025年3月8日
    200
  • Node.Js实现端口重用步骤详解

    这次给大家带来Node.Js实现端口重用步骤详解,Node.Js实现端口重用的注意事项有哪些,下面就是实战案例,一起来看一下。 起源,从官方实例中看多进程共用端口 const cluster = require(‘cluster’);con…

    编程技术 2025年3月8日
    200

发表回复

登录后才能评论