vue文件树组件使用详解

本文实例为大家分享了vue文件树组件的实现方法,供大家参考,具体内容如下

本文主要是分析vue官方仓库里的文件树组件[vue github]

demo可以查看 nofollow" target="_blank" href="https://codepen.io/shayminsky21/pen/xXwxgm">https://codepen.io/shayminsky21/pen/xXwxgm

首先是html模板:

rush:xhtml;">
  • 文件夹加粗表示 :class="{bold: isFolder}" //处理单击事件 打开闭合文件列表 @click="toggle" //处理双击事件 双击子文件,子文件属性变为文件夹 @dblclick="changeType"> //显示文件名 {{model.name}} //若是文件夹的话则显示[+]来控制文件夹的开关闭
  • 接下来是组件部分的源码:

    rush:js;"> Vue.component('item',{ template: '#item-template',props: { model: Object //将文件数据通过props传入 },data: function () { return { open: false //open表示文件夹闭合状态 } },computed: { isFolder: function () { return this.model.children && this.model.children.length } },//计算对象是否有子节点并且子节点数大于0来判断是否是文件夹 methods: { toggle: function () { if (this.isFolder) { this.open = !this.open } },//控制文件夹闭合的方法 单击触发改变open changeType: function () { if (!this.isFolder) { Vue.set(this.model,'children',[]) this.addChild() this.open = true } },//双击触发,通过给文件增加子节点来使文件属性变成文件夹 addChild: function () { this.model.children.push({ name: 'new stuff' }) //点击文件夹里的+节点触发 为文件添加一个文件 } } })

    所以设计思路就是通过判断对象是否有子节点来决定是文件夹还是文件,然后通过递归复用组件来展示文件树的效果

    最后是传入组件的数据格式:

    rush:js;"> var data = { name: 'My Tree',children: [ { name: 'hello' },{ name: 'wat' },{ name: 'child folder',children: [ { name: 'child folder',children: [ { name: 'hello' },{ name: 'wat' } ] },{ name: 'hello' },{ name: 'child folder',{ name: 'wat' } ] } ] } ] }

    大家可以根据这个基本的结构继续拓展文件树的功能和展示效果

    以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

    相关文章

    可以通过min-width属性来设置el-table-column的最小宽度。以...
    yarn dev,当文件变动后,会自动重启。 yanr start不会自动重...
    ref 用于创建一个对值的响应式引用。这个值可以是原始值(如...
    通过修改 getWK005 函数来实现这一点。这里的 query 参数就是...
    <el-form-item label="入库类型" ...
    API 变动 样式类名变化: 一些组件的样式类名有所变动,可能需...