使用Vue如何制作组织架构树组件

最近公司在做一个基于vue开发的项目,项目需要开发一个展示组织架构的树组件,在网上搜了半天,没有找到合适的,下面小编给大家分享一个基于vue制作组织架构树组件,需要的朋友参考下吧

使用Vue如何制作组织架构树组件

由于公司业务需求,需要开发一个展示组织架构的树组件(公司的项目是基于Vue)。在GitHub上找了半天,这类组件不多,也没有符合业务需求的组件,所以决定自己造轮子!

分析

既然是树,那么每个节点都应该是相同的组件

节点下面套节点,所以节点组件应该是一个 递归组件

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

那么,问题来了。递归组件怎么写?

递归组件

Vue官方文档是这样说的:

组件在它的模板内可以递归地调用自己。不过,只有当它有 name 选项时才可以这么做

接下来,我们来写一个树节点递归组件:

 

 

{{data.label}}

  

   

  export default { name: 'OrgTreeNode', props: { data: Object } } /* ... */

登录后复制

然后渲染这个这个组件,效果如下

使用Vue如何制作组织架构树组件 

至此,一个简单的组织架构树组件就完成了。

然而,事情还远远没有结束。。。

需求说:节点的label要支持定制,树要支持水平展示!

因此,我们对递归组件作如下修改:

 

 

  {{data.label}} 

  

   

  export default { name: 'OrgTreeNode', props: { data: Object } } /* ... */

登录后复制

我们使用slot插槽来支持label可定制,但是问题又来了:我们发现只有第一层级的节点label能定制,嵌套的子节点不能有效的传递slot插槽。上网查了半天,仍然没有结果,于是再看官方文档。发现有个函数式组件。由于之前使用过 element-ui 的 tree 组件,受到启发,就想到了可以像 element-ui 的 tree 组件一样传一个 renderContent 函数,由调用者自己渲染节点label,这样就达到了节点定制的目的!

函数式组件

接下来,我们将树节点模板组件改造成函数式组件。编写node.js:

首先我们实现一个render函数

export const render = (h, context) => { const {props} = context return renderNode(h, props.data, context)}

登录后复制

实现renderNode函数

export const renderNode = (h, data, context) => { const {props} = context const childNodes = [] childNodes.push(renderLabel(h, data, context)) if (props.data.children && props.data.children.length) { childNodes.push(renderChildren(h, props.data.children, context)) } return h('p', { domProps: { className: 'org-tree-node' } }, childNodes)}

登录后复制

实现renderLabel函数。节点label定制关键在这里:

export const renderLabel = (h, data, context) => { const {props} = context const renderContent = props.renderContent const childNodes = [] // 节点label定制,由调用者传入的renderContent实现 if (typeof renderContent === 'function') { let vnode = renderContent(h, props.data) vnode && childNodes.push(vnode) } else { childNodes.push(props.data.label) } return h('p', { domProps: { className: 'org-tree-node-label' } }, childNodes)}

登录后复制

实现renderChildren函数。这里递归调用renderNode,实现了递归组件

export const renderChildren = (h, list, context) => { if (Array.isArray(list) && list.length) { const children = list.map(item => { return renderNode(h, item, context) }) return h('p', { domProps: { className: 'org-tree-node-children' } }, children) } return ''}

登录后复制

至此我们的render函数完成了,接下来使用render函数定义函数式组件。在tree组件里面声明:

  import render from './node.js' export default { name: 'OrgTree', components: {  OrgTreeNode: {  render,  // 定义函数式组件  functional: true  } } }

登录后复制

至此我们的函数式组件改造完成了,至于水平显示用样式控制就可以了。

CSS样式

样式使用less预编译。节点之间的线条采用了 :before 、 :after 伪元素的 border 绘制

功能扩展

添加了 labelClassName 属性,以支持对节点label的样式定制

添加了 labelWidth 属性,用于限制节点label的宽度

添加了 props 属性,参考 element-ui 的 tree 组件的props属性,以支持复杂的数据结构

添加了 collapsable 属性,以支持子节点的展开和折叠(展开和折叠操作需调用者实现)

刚开始采用了 flex 布局,但是要兼容IE9,后来改成了 display: table 布局

最终效果:

default

使用Vue如何制作组织架构树组件

horizontal

使用Vue如何制作组织架构树组件

问题总结

可以定义一个树的store,存储每个节点状态,这样就可以在内部维护树节点的展开可收起状态

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

相关文章:

在微信小程序中如何实现图片上传等一系列功能

在微信小程序中如何实现图片上传等一系列功能

在微信小程序中如何实现图片上传等一系列功能

在微信小程序中如何实现图片上传等一系列功能

以上就是使用Vue如何制作组织架构树组件的详细内容,更多请关注【创想鸟】其它相关文章!

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

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

(0)
上一篇 2025年3月8日 05:01:35
下一篇 2025年3月8日 05:01:42

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

相关推荐

  • 使用vue如何制作Tab组件

    这篇文章主要给大家介绍了关于利用vue组件自定义v-model实现一个tab组件的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。 前言 最近在学习vue,今天…

    2025年3月8日
    200
  • 如何重置vue打印变量的显示方式(详细教程)

    这篇文章主要给大家介绍了关于如何重置vue打印变量显示方式的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起看看吧。 前言 我们在日常开发中,经常会碰到vue使用conso…

    2025年3月8日
    200
  • 在vue中有关cli使用绝对路径引用问题

    这篇文章主要给大家介绍了关于vue cli使用绝对路径引用图片问题的解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起看看吧。 前言 Vue是什么,是一套构建用户界面的渐进式…

    编程技术 2025年3月8日
    200
  • 在vue中如何实现picker效果

    这篇文章主要介绍了vue 实现 ios 原生picker 效果及实现思路解析,本文给大家介绍的非常详细,具有参考借鉴价值,需要的朋友可以参考下 以前最早实现了一个类似的时间选择插件,但是适用范围太窄,索性最近要把这个实现方式发布出来,就重写…

    2025年3月8日 编程技术
    200
  • 在Vue中有关DevTools调试工具的使用方法

    本篇文章主要介绍了vue devtools调试工具的使用,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧 因为工作要求,目前主要在用Vue.js技术栈做开发,调试是必不可少的,这里会用的Vue DevTools的…

    2025年3月8日 编程技术
    200
  • 如何解决把Vue项目部署到服务器上出现的问题

    本篇文章主要介绍了vue 项目部署到服务器的问题解决方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧 相信很多小伙伴在用Vue-cli安装的脚手架开发的时候,在开发环境中项目可以很正常的运行,但是进入到生产环…

    2025年3月8日
    200
  • 在vue中有关计算属性如何使用

    本篇文章主要介绍了vue计算属性的使用和vue实例的方法示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧 本文介绍了vue计算属性的使用和vue实例的方法示例,分享给大家,具体如下: 计算属性 在模板中表达式…

    编程技术 2025年3月8日
    200
  • 在Vue中如何导出json数据到Excel电子表格

    本篇主要介绍了vue导出json数据到excel电子表格的示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧 网上看了很多文档感觉都不全,这里写一篇完整的详细教程。 一、安装依赖(前面基本一样) npm ins…

    2025年3月8日 编程技术
    200
  • 在vue中有关eventbus的详细解读

    这篇文章主要介绍了vue中eventbus被多次触发以及踩过的坑,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧 一开始的需求是这样子的,我为了实现两个页面组件之间的数据传递,假设我有页面A,点击页面A上的某一个…

    2025年3月8日 编程技术
    200
  • 在Vue-Access-Control中有关前端用户权限控制(详细教程)

    vue-access-control是一套基于vue/vue-router/axios 实现的前端用户权限控制解决方案。这篇文章主要介绍了vue-access-control:前端用户权限控制解决方案,需要的朋友可以参考下 Vue-Acce…

    编程技术 2025年3月8日
    200

发表回复

登录后才能评论