ZtTree树形控件

简介

安装zt-ui依赖的包

npm install vue -S
npm install vue-router -S
npm install element-ui -S
或
cnpm install vue -S
cnpm install vue-router -S
cnpm install element-ui -S

安装zt-ui

npm install zt-ui -S
或者
cnpm install zt-ui -S 

引用引zt-ui包

// 引zt-ui包
// 我们的zt-ui也提供了按需引包
import { ZtTable } from 'zt-ui';
Vue.use(ZtTable);

ZtTree Attributes组件属性

参数 说明 类型 可选值 默认值
treeData tree树形控件数据 Object 请参考下面TreeData Attributes
empty-text 内容为空的时候展示的文本 String
highlightCurrent 是否高亮当前选中节点 Boolean false
default-expand-all 是否默认展开所有节点 Boolean false
expand-on-click-node 是否在点击节点的时候展开或者收缩节点, 默认值为 true,如果为 false,则只有点箭头图标的时候才会展开或者收缩节点 Boolean true
auto-expand-parent 展开子节点的时候是否自动展开父节点 Boolean true
node-key 每个树节点用来作为唯一标识的属性,整颗树应该是唯一的 String
default-expanded-keys 默认展开的节点的 key 的数组,与node-key结合使用 Array
show-checkbox 节点是否可被选择 Boolean false
check-strictly 在显示复选框的情况下,是否严格的遵循父子不互相关联的做法 Boolean false
indent 相邻级节点间的水平缩进,单位为像素 Number 16
tree tree Object
tree tree Object

TreeData Attributes 数据属性

参数 说明 类型 可选值 默认值
treeData tree树形控件件数据 ,扁平化数据 Array
treeRelation tree树形控件件父子数据关系 Object

TreeRelation Attributes 父子数据关系属性

参数 说明 类型 可选值 默认值
id 数据里的id String
pid 数据里的父id String
children 生成结果中子节点的字段名 String
showData tree展示字段 String
treeData:{
    treeData:[
        {id: 6, parent_id: 2,showData:'在tree显示的内容', data: '这是其他数据'},
        {id: 7, parent_id: 3, showData:'在tree显示的内容',data: '这是其他数据'},
        {id: 2, parent_id: 1, showData:'在tree显示的内容',data: '这是其他数据'},
        {id: 4, parent_id: 2, showData:'在tree显示的内容',data: '这是其他数据'},
        {id: 1, parent_id: 0, showData:'在tree显示的内容',data: '这是其他数据'},
        {id: 9, parent_id: 5, showData:'在tree显示的内容',data: '这是其他数据'},
        {id: 8, parent_id: 3, showData:'在tree显示的内容',data: '这是其他数据'},
        {id: 3, parent_id: 1, showData:'在tree显示的内容',data: '这是其他数据'},
        {id: 5, parent_id: 2, showData:'在tree显示的内容',data: '这是其他数据'},
        {id: 10, parent_id:6, showData:'在tree显示的内容',data: '这是其他数据'}
    ]
    treeRelation:{
        id: 'id',
        pid: 'parent_id',
        children: 'kids',
        showData:'showData'
    }

上面的扁平化数据最终转化成以下树形json数据

[
    {
        "id": 1,
        "parent_id": 0,
        "data": "这是其他数据",
        'showData': '在tree显示的内容',
        "kids": [
            {
                "id": 2,
                "parent_id": 1,
                "data": "这是其他数据",
                'showData': '在tree显示的内容',
                "kids": [
                    {
                        "id": 6,
                        "parent_id": 2,
                        "data": "这是其他数据",
                        'showData': '在tree显示的内容',
                        "kids": [
                            {
                                "id": 10,
                                "parent_id": 6,
                                "data": "这是其他数据",
                                'showData': '在tree显示的内容',
                            }
                        ]
                    },
                    {
                        "id": 4,
                        "parent_id": 2,
                        "data": "这是其他数据",
                        'showData': '在tree显示的内容',
                    },
                    {
                        "id": 5,
                        "parent_id": 2,
                        "data": "这是其他数据",
                        'showData': '在tree显示的内容',
                        "kids": [
                            {
                                "id": 9,
                                "parent_id": 5,
                                "data": "这是其他数据",
                                'showData': '在tree显示的内容',
                            }
                        ]
                    }
                ]
            },
            {
                "id": 3,
                "parent_id": 1,
                "data": "这是其他数据",
                'showData': '在tree显示的内容',
                "kids": [
                    {
                        "id": 7,
                        "parent_id": 3,
                        "data": "这是其他数据",
                        'showData': '在tree显示的内容',
                    },
                    {
                        "id": 8,
                        "parent_id": 3,
                        "data": "这是其他数据",
                        'showData': '在tree显示的内容',
                    }
                ]
            }
        ]
    }
]

上面的扁平化数据最终转化成以下树形json数据呈现的样式

扁平化数据最终转化成以下树形json数据呈现的样式

Tree方法

方法名 说明 参数
getCheckedNodes 若节点可被选择(即 show-checkbox 为 true),则返回目前被选中的节点所组成的数组 (leafOnly) 接收一个 boolean 类型的参数,若为 true 则仅返回被选中的叶子节点,默认值为 false
setCheckedNodes 设置目前勾选的节点,使用此方法必须设置 node-key 属性 (nodes) 接收勾选节点数据的数组
getCheckedKeys 若节点可被选择(即 show-checkbox 为 true),则返回目前被选中的节点所组成的数组 (leafOnly) 接收一个 boolean 类型的参数,若为 true 则仅返回被选中的叶子节点的 keys,默认值为 false
setCheckedKeys 通过 keys 设置目前勾选的节点,使用此方法必须设置 node-key 属性 (keys, leafOnly) 接收两个参数,1. 勾选节点的 key 的数组 2. boolean 类型的参数,若为 true 则仅设置叶子节点的选中状态,默认值为 false
setChecked 通过 key / data 设置某个节点的勾选状态,使用此方法必须设置 node-key 属性 (key/data, checked, deep) 接收三个参数,1. 勾选节点的 key 或者 data 2. boolean 类型,节点是否选中 3. boolean 类型,是否设置子节点 ,默认为 false

ZtTree Events 事件

事件名称 说明 回调参数
node-click 节点被点击时的回调 共三个参数,依次为:传递给 data 属性的数组中该节点所对应的对象、节点对应的 Node、节点组件本身。
current-change 当前选中节点变化时触发的事件 共两个参数,依次为:当前节点的数据,当前节点的 Node 对象
node-expand 节点被展开时触发的事件 共三个参数,依次为:传递给 data 属性的数组中该节点所对应的对象、节点对应的 Node、节点组件本身。
node-collapse 节点被关闭时触发的事件 共三个参数,依次为:传递给 data 属性的数组中该节点所对应的对象、节点对应的 Node、节点组件本身。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,732评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,496评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,264评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,807评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,806评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,675评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,029评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,683评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,704评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,666评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,773评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,413评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,016评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,204评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,083评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,503评论 2 343

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,448评论 25 707
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,596评论 18 139
  • 网络连接错误比较常见的原因是内网地址无法访问、端口权限没配置,前一个好解决,后一个需要检查多个地方的配置。连接经过...
    _Rogan阅读 1,522评论 0 0
  • 美丽的九寨 天府之国 昨日的地震 让它失去了往日的容颜 九寨 我们来了 在第一时间 披星戴月 日夜兼程 跑步前进 ...
    caoxia阅读 135评论 11 14
  • 那首熟悉的歌又响起。 多少事,已经改变。 年少的懵懂与单纯。 沧海桑田后的无语。 人生,原来如此! 不经意,错过春...
    天涯颦儿阅读 245评论 0 0