前言:因为现成的tree组件没有找到。亦或是其依赖的其他东西太多,不太合适引入我们的项目,所以自己做了一个。大概样式:

在线例子:

https://hamupp.github.io/t-vue-tree/examples/dist/#/basicDemoAndApi

属性:

1.data {类型Object} 树的全部数据,格式参考下例,其中的各个字段的说明也看示例中的注释。在此基础上你当然可以追加自己的字段。

 [
{
title: 'parent 1',
expanded: true,
checkbox: true,//是否有勾选框,默认false
checked: false,//是否勾选该节点,默认false
selected: false,//是否选中该节点,默认false
custormKey: 'ccdf',
children: [
{
title: 'parent 1-1',
expanded: true,
checkbox: true,//是否有勾选框,默认false
checked: false,//是否勾选该节点,默认false
custormKey: 'ccdf',
children: [
{
title: 'leaf 1-1-1',
checkbox: true,//是否有勾选框,默认false
checked: false,//是否勾选该节点,默认false
custormKey: 'ccdf',
},
{
title: 'leaf 1-1-2',
checkbox: true,//是否有勾选框,默认false
checked: false,//是否勾选该节点,默认false
selected:true,//是否选中该节点,默认false
custormKey: 'ccdf',
}
]
},
{
title: 'parent 1-2',
expanded: true,
checkbox: true,//是否有勾选框,默认false
checked: false,//是否勾选该节点,默认false
custormKey: 'ccdf',
children: [
{
title: 'leaf 1-2-1',
checkbox: true,//是否有勾选框,默认false
checked: false,//是否勾选该节点,默认false
custormKey: 'ccdf',
children: [
{
title: 'leaf 1-2-1-1',
checkbox: true,//是否有勾选框,默认false
checked: false,//是否勾选该节点,默认false
custormKey: 'mmccf',
},
{
title: 'leaf 1-2-1-2',
checkbox: true,//是否有勾选框,默认false
checked: false,//是否勾选该节点,默认false
custormKey: 'mmccf',
},
{
title: 'leaf 1-2-1-3',
checkbox: true,//是否有勾选框,默认false
checked: false,//是否勾选该节点,默认false
custormKey: 'mmccf',
}
]
},
{
title: 'leaf 1-2-1',
checkbox: true,//是否有勾选框,默认false
checked: false,//是否勾选该节点,默认false
custormKey: 'ccdf',
}
]
}
]
},
{
title: 'parent 2',
expanded: false,
checkbox: true,//是否有勾选框,默认false
checked: true,//是否勾选该节点,默认false
children: [
{
title: 'parent 2-1',
checkbox: true,//是否有勾选框,默认false
checked: true,//是否勾选该节点,默认false
expanded: true,//是否展开该节点
selected: false,//是否选中该节点,默认false
expandOnClickNode: false,//点击节点时也展开节点,需要expand属性同时为真,默认false
children: [
{
title: 'leaf 2-1-1',
checkbox: true,//是否有勾选框,默认false
checked: true,//是否勾选该节点,默认false
},
{
title: 'leaf 2-1-2',
checkbox: true,//是否有勾选框,默认false
checked: true,//是否勾选该节点,默认false
}
]
},
{
title: 'parent 2-2',
expanded: true,
checkbox: true,//是否有勾选框,默认false
checked: true,//是否勾选该节点,默认false
children: [
{
title: 'leaf 2-2-1',
checkbox: true,//是否有勾选框,默认false
checked: true,//是否勾选该节点,默认false
},
{
title: 'leaf 2-2-1',
checkbox: true,//是否有勾选框,默认false
checked: true,//是否勾选该节点,默认false
}
]
}
]
}
]

2.treeSelectable {类型Boolean} 树节点是否有选中效果。默认true

3.treeSelectType {类型String} 仅限两个值single|multiple。默认single。树节点的选中效果是单选还是允许多选,正常来说,树节点的选中效果都是单选,即选中一个节点时,取消之前选中的节点。但就是有些骚包反人类客户想要多选效果

**ps:**

1.treeSelectable为false时,treeSelectType无效,节点本身的selected字段无效。

2.关于勾选框的,没有通用的勾选框属性配置。如果要加勾选框,请将每个节点的内部的checkbox字段设为true,否则该节点没有勾选框

事件:

1.onToggle 折叠展开一个节点时触发。返回该节点的所有数据
2.onCheck 勾选|取消勾选一个节点时触发。返回该节点的所有数据
3.onSelect 选择|取消选中一个节点时触发。返回该节点的所有数据

方法:

1.getCheckedNodes 参数:String 仅限两个值:checked indeterminated 获取勾选的节点,实心和非实心。返回:Array,勾选的实心或者半实心的节点的集合

2.getSelectedNodes 参数:无,返回:Array,选中的节点的集合

下载安装和引入方式:

1.npm install t-vue-tree

2.引入并注册为vue的组件:

方式分2种--全局注册or局部注册

(1)全局注册:

在你的vue项目的入口js中(按照惯例,这个js一般取名为main.js或者app.js或者index.js)注册为全局的vue组件,然后在所有vue文件中都可以直接使用:

> 例如:main.js中:
<!-- 你的其他代码 --start--     -->
...
import Vue from 'vue'
...
<!-- 你的其他代码 --end-- --> <!-- 引入本tree组件 --start-- -->
import Ttree from 't-vue-tree';
Vue.component('Ttree', Ttree);
<!-- 引入本tree组件 --end-- -->
> 然后在需要使用的vue页面中:
<template>
<!-- 先为tree组件设定一个包裹元素,并设置其宽高-->
<div class='your-tree-wrapper'> <!-- 里面写tree组件-->
<Ttree
:data="treeData"
></Ttree>
</div>
</template>

其中treeData的数据参考上文‘属性’说明中的data的说明;

(2)局部注册

在需要使用tree的vue页面中单独引入并注册为一个局部的组件:

>  demo.vue

<template>
  <div class='your-tree-wrapper'>
    <Ttree
      :data="treeData"
    ></Ttree>
  </div>
</template>

<script>
import Ttree from 't-vue-tree';//引入本组件 export default {
components: {//注册本组件
Ttree
},
data(){
return{
          treeData:[。。。数据参考属性一节的data的说明。。。]
}
}
}

**注意:**
不论哪种方式引入,在vue页面中使用时,一定要把本组件放在一个你的包裹dom元素中,例如上例中的.your-tree-wrapper的div。因为本tree的宽高css是100%,所以,如果父容器没有宽高。。。。你懂得撒。。。

git地址:

https://github.com/hamuPP/t-vue-tree

NPM地址:

https://www.npmjs.com/package/t-vue-tree

做了一个vue的同步tree 的npm组件包的更多相关文章

  1. 发布自己第一个npm 组件包(基于Vue的文字跑马灯组件)

    一.前言 总结下最近工作上在移动端实现的一个跑马灯效果,最终效果如下: 印象中好像HTML标签的'marquee'的直接可以实现这个效果,不过 HTML标准中已经废弃了'marquee'标签 既然HT ...

  2. 从0开始做一个的Vue图片/ 文件选择(上传)组件[基础向]

    原文:http://blog.csdn.net/sinat_17775997/article/details/58585142 之前用Vue做了一个基础的组件 vue-img-inputer ,下面就 ...

  3. 跟我一起做一个vue的小项目(二)

    这个vue项目是紧跟着之前的项目跟我一起做一个vue的小项目(一)来的. 我继续后面的开发(写的比较粗糙,边学边记录) 下图是header头部的样式 header组件内容如下 //header.vue ...

  4. 如何写好一个vue组件,老夫的一年经验全在这了【转】 v-bind="$attrs" 和 v-on="$listeners"

    如何写好一个vue组件,老夫的一年经验全在这了 一个适用性良好的组件,一种是可配置项很多,另一种就是容易覆写,从而扩展功能 Vue 组件的 API 来自三部分——prop.事件和插槽: prop 允许 ...

  5. 撸一个vue的双向绑定

    1.前言 说起双向绑定可能大家都会说:Vue内部通过Object.defineProperty方法属性拦截的方式,把data对象里每个数据的读写转化成getter/setter,当数据变化时通知视图更 ...

  6. 如何抽象一个 Vue 公共组件

    之前一直想写一篇关于抽象 Vue 组件的随笔,无奈一直没想到好的例子.恰巧最近为公司项目做了一个数字键盘的组件,于是就以这个为例聊聊如何抽象 Vue 的组件. 先上 Demo 与 源码.(demo最好 ...

  7. 读懂源码:一步一步实现一个 Vue

    源码阅读:究竟怎样才算是读懂了? 市面上有很多源码分析的文章,就我看到的而言,基本的套路就是梳理流程,讲一讲每个模块的功能,整篇文章有一大半都是直接挂源码.我不禁怀疑,作者真的看懂了吗?为什么我看完后 ...

  8. 创建一个vue项目的过程

    创建一个vue项目: 1.首先从UI手上拿到PSD设计图,然后看设计搞的内容,需要做个大概的页面布局 2.做vue之前不许安装node,因为做vue项目要和node结合使用 3.然后安装vue脚手架: ...

  9. 如何用vue-cli初始化一个vue项目

    单文件组件和vue-loader 解析打包.vue文件 vue为了能够使我们在项目开发中对组件进行更好的维护,提供了一个单文件组件系统,vue把每一个独立的组件放在一个.vue的文件中,在这个文件中提 ...

随机推荐

  1. 论文笔记——NEURAL ARCHITECTURE SEARCH WITH REINFORCEMENT LEARNING

    论文地址:https://arxiv.org/abs/1611.01578 1. 论文思想 强化学习,用一个RNN学一个网络参数的序列,然后将其转换成网络,然后训练,得到一个反馈,这个反馈作用于RNN ...

  2. [JVM] - 不就是JVM么 JVM的继续探究

    前面几章跟着作者的脚步实现了使用Go语言查看java的.class文件源码(16进制) 复习一下: 相比Java语言,Go的访问控制非常简单,只有公开和私有两种. 所有首字母大写的类型, 结构体,字段 ...

  3. ASP.NET Web API 2入门

    1.全局配置 Web API 2之前是这样的配置的: protected void Application_Start() { //未实现特性路由 WebApiConfig.Register(Glob ...

  4. NOI 4978 宠物小精灵之收服(二维背包)

    http://noi.openjudge.cn/ch0206/4978/ 描述 宠物小精灵是一部讲述小智和他的搭档皮卡丘一起冒险的故事. 一天,小智和皮卡丘来到了小精灵狩猎场,里面有很多珍贵的野生宠物 ...

  5. Ubuntu 关闭防火墙

    关闭防火墙:service iptables stop

  6. package 'orocos-bfl' not found CMake Error at /usr/share/cmake-2.8/Modules/FindPkgConfig.cmake:283 (message):

    #没有数字 sudo apt-get install ros-indigo-bfl

  7. Java 常用对象-基本类型的封装类

    2017-11-04 20:39:26 基本类型封装类:基本类型的封装类的好处是可以在对象中定义更多的功能方法操作该数据. 常用操作之一:用于基本数据类型与字符串的转换. 基本类型和包装类的对应: b ...

  8. delphi文件名获取方法

    取文件名 ExtractFileName(FileName); 取文件扩展名: ExtractFileExt(filename); 取文件名,不带扩展名: 方法一:   Function Extrac ...

  9. ASP.NET调用dos命令获取交换机流量

    protected void btn_Cisco_Click(object sender, EventArgs e) { try { string ip = txt_ip.Value; string ...

  10. windows 命令巧用(持续更新)

    netstat -ano netstat -anvb netstat -s -p [tcp|udp|ip|icmp] # 关闭/打开防火墙 netsh firewall set opmode disa ...