0

0

vue文件树组件使用详解

亚连

亚连

发布时间:2018-05-28 11:27:59

|

2562人浏览过

|

来源于php中文网

原创

这篇文章主要为大家详细介绍了vue文件树组件的使用方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

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

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

首先是html模板:

  • //显示文件名 {{model.name}} //若是文件夹的话则显示[+]来控制文件夹的开关闭合 [{{open ? '-' : '+'}}]

      //利用v-for显示子文件列表,通过递归使用item组件来完成文件树 //增加一个+标记,单击可以增加子文件
    • +
  • 立即学习前端免费学习笔记(深入)”;

    接下来是组件部分的源码:

    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'
      })  //点击文件夹里的+节点触发 为文件夹添加一个新文件
     }   
     }
    })

    立即学习前端免费学习笔记(深入)”;

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

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

    mallcloud商城
    mallcloud商城

    mallcloud商城基于SpringBoot2.x、SpringCloud和SpringCloudAlibaba并采用前后端分离vue的企业级微服务敏捷开发系统架构。并引入组件化的思想实现高内聚低耦合,项目代码简洁注释丰富上手容易,适合学习和企业中使用。真正实现了基于RBAC、jwt和oauth2的无状态统一权限认证的解决方案,面向互联网设计同时适合B端和C端用户,支持CI/CD多环境部署,并提

    下载

    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: 'wat' },
      {
       name: 'child folder',
       children: [
       { name: 'hello' },
       { name: 'wat' }
       ]
      }
      ]
     }
     ]
    }

    立即学习前端免费学习笔记(深入)”;

    上面是我整理给大家的,希望今后会对大家有帮助。

    相关文章:

    原生nodejs使用websocket代码分享

    详解nodejs通过响应回写的方式渲染页面资源

    vue下拉列表功能实例代码

    立即学习前端免费学习笔记(深入)”;

    相关专题

    更多
    php源码安装教程大全
    php源码安装教程大全

    本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

    7

    2025.12.31

    php网站源码教程大全
    php网站源码教程大全

    本专题整合了php网站源码相关教程,阅读专题下面的文章了解更多详细内容。

    4

    2025.12.31

    视频文件格式
    视频文件格式

    本专题整合了视频文件格式相关内容,阅读专题下面的文章了解更多详细内容。

    7

    2025.12.31

    不受国内限制的浏览器大全
    不受国内限制的浏览器大全

    想找真正自由、无限制的上网体验?本合集精选2025年最开放、隐私强、访问无阻的浏览器App,涵盖Tor、Brave、Via、X浏览器、Mullvad等高自由度工具。支持自定义搜索引擎、广告拦截、隐身模式及全球网站无障碍访问,部分更具备防追踪、去谷歌化、双内核切换等高级功能。无论日常浏览、隐私保护还是突破地域限制,总有一款适合你!

    7

    2025.12.31

    出现404解决方法大全
    出现404解决方法大全

    本专题整合了404错误解决方法大全,阅读专题下面的文章了解更多详细内容。

    42

    2025.12.31

    html5怎么播放视频
    html5怎么播放视频

    想让网页流畅播放视频?本合集详解HTML5视频播放核心方法!涵盖<video>标签基础用法、多格式兼容(MP4/WebM/OGV)、自定义播放控件、响应式适配及常见浏览器兼容问题解决方案。无需插件,纯前端实现高清视频嵌入,助你快速打造现代化网页视频体验。

    4

    2025.12.31

    关闭win10系统自动更新教程大全
    关闭win10系统自动更新教程大全

    本专题整合了关闭win10系统自动更新教程大全,阅读专题下面的文章了解更多详细内容。

    3

    2025.12.31

    阻止电脑自动安装软件教程
    阻止电脑自动安装软件教程

    本专题整合了阻止电脑自动安装软件教程,阅读专题下面的文章了解更多详细教程。

    3

    2025.12.31

    html5怎么使用
    html5怎么使用

    想快速上手HTML5开发?本合集为你整理最实用的HTML5使用指南!涵盖HTML5基础语法、主流框架(如Bootstrap、Vue、React)集成方法,以及无需安装、直接在线编辑运行的平台推荐(如CodePen、JSFiddle)。无论你是新手还是进阶开发者,都能轻松掌握HTML5网页制作、响应式布局与交互功能开发,零配置开启高效前端编程之旅!

    2

    2025.12.31

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

    更多
    相关推荐
    /
    热门推荐
    /
    最新课程
    Go 教程
    Go 教程

    共32课时 | 3.1万人学习

    麻省理工大佬Python课程
    麻省理工大佬Python课程

    共34课时 | 5万人学习

    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

    Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号