工作上使用到element-ui tree 组件,主要功能是要实现节点拖拽和置顶,通过自定义内容方法(render-content)渲染树代码如下~
 
 <template>
<div class="sortDiv">
<el-tree :data="sortData" draggable node-key="id" ref="sortTree" default-expand-all :expand-on-click-node="false" :render-content="renderContent" :allow-drop="allowDrop">
</el-tree>
<el-button @click="getData">获取数据</el-button>
</div>
</template>
<script>
export default {
name: 'Sort',
data() {
return {
sortData: [
{
id: ,
label: '一级 1',
checkItem: true,
children: [
{
id: ,
label: '二级 1-1',
checkItem: false
},
{
id: ,
label: '二级 1-2',
checkItem: false
},
{
id: ,
label: '二级 1-3',
checkItem: false
}
]
},
{
id: ,
label: '一级 2',
checkItem: true,
children: [
{
id: ,
label: '二级 2-1',
checkItem: true
},
{
id: ,
label: '二级 2-2',
checkItem: true
}
]
},
{
id: ,
label: '一级 3',
checkItem: true,
children: [
{
id: ,
label: '二级 3-1',
checkItem: true
},
{
id: ,
label: '二级 3-2',
checkItem: false
}
]
}
]
};
},
methods: {
// 是否允许拖拽
allowDrop (draggingNode, dropNode, type) {
if (draggingNode.parent === dropNode.parent) {
return type !== 'inner'
}
else return false
},
//获取数据
getData () {
let result = this.$refs['sortTree'].data;
let sortRulesMaps = [];
result.forEach((element, index) => {
let item = null;
if (element.checkItem) {
if (element.children && element.children.length > ) {
item = {
orderIndex: index,
sortField: element.label,
rule: ['OTHERS']
};
element.children.forEach(i => {
if (i.checkItem) {
item.rule.push(i.label);
}
});
item.rule = item.rule.join('_');
}
}
item && sortRulesMaps.push(item);
});
},
//同级置顶功能
toTop(node, data) {
let c = Object.assign({}, data);
if (node.parent.level === ) {
this.sortData.unshift(c)
} else {
node.parent.data.children.unshift(c);
}
this.$refs['sortTree'].remove(data.id);
},
changeNode(r, node, data) {
data.checkItem = r;
},
//自定义内容
renderContent(h, { node, data }) {
return (
<span class="custom-tree-node">
<span>{data.label}</span>
<span>
<el-checkbox
v-model={data.checkItem}
checked={data.checkItem}
on-change={r => this.changeNode(r, node, data)}
/>
<el-button
size="mini"
type="text"
on-click={() => this.toTop(node, data)}
style="color:#707375;margin-left:10px"
>
<i class="fa fa-arrow-up">置顶</i>
</el-button>
</span>
</span>
);
}
}
};
</script>
<style lang="scss">
.sortDiv {
.el-icon-caret-right:before {
content: '\E604';
}
}
.custom-tree-node {
flex: ;
display: flex;
align-items: center;
justify-content: space-between;
font-size: 14px;
padding-right: 8px;
}
</style>

Element-ui tree组件自定义节点使用方法的更多相关文章

  1. element ui table组件自定义合计栏,后台给的数据

    合计的数据是后台传的,所以用table组件自定义一行用来合计 <el-table border fit v-loading.body="listLoading" elemen ...

  2. Element ui tree树形控件获取当前节点id和父节点id

    低版本Element ui tree树形控件获取当前节点id和父节点id的方法:点击查看 最新版本Element ui tree树形控件获取当前节点id和父节点id教程: 1.找到node_modul ...

  3. [转]vue Element UI走马灯组件重写

    https://blog.csdn.net/u013750989/article/details/82885482 1.element ui走马灯组件 -- carousel分析一波源代码:carou ...

  4. Element UI tree 回显问题

    Part.1 问题 写项目时遇到一个棘手的问题,在做关于权限功能时,点击修改需要显示角色原本对应的权限.涉及到了 tree 组件回显,但是有一个很尴尬的问题:tree 组件只要父节点选中,那么子节点就 ...

  5. element ui table render-header自定义表头信息使用

    在使用vue自定义组件内容过程之中,我们绝大多数情况下都是通过预先写好不同的html模板,再通过props传入不同的值来渲染不同的模板.例如我们需要实现一个<v-title size='1'&g ...

  6. element ui tree回显 setCheckedNodes,setCheckedKeys,setChecked等函数报undefined问题

    在写项目的时候,需要用到tree组件进行回显来进行权限控制: 在回显过程中使用回显函数会报报undefined, 这时只需要给该函数包裹一层nextTick方法就行了, 在回显过程中我们有可能使用半选 ...

  7. vue的$nextTick使用总结,this.$refs为undefined的解决办法,element Ui的树形控件setCheckedKeys方法无法使用

    其实这3个讲的是一个问题,先说下问题,我在watch里设置一个监听,当弹窗打开时,自动添加树形的默认选中项, 但奇怪的是this.$refs为undefined,自然setCheckedKeys无法使 ...

  8. Element ui tree结合Vue使用遇到的一些问题(一)

    下图是一个后台管理系统,展示的是角色列表 当我点击编辑的时候,弹出一个模态框,如下图 功能需求:点击编辑按钮,弹出模态框,选择权限那块,默认选中当前角色拥有的权限. 问题:第一次点击编辑按钮时,不会选 ...

  9. 封装一个优雅的element ui表格组件

    现在做后台系统用vue + elementUI 的越来越多,那element ui的 el-table 组件肯定也离不开.虽然element ui的table组件很好.但是表格和分页是分离的.每次写表 ...

随机推荐

  1. IOS 版本控制判断

    // 版本判断#define SYSTEM_VERSION(ver) [[[UIDevice currentDevice] systemVersion] compare:ver] != NSOrder ...

  2. Laravel Model 利用 Macroable 为数据模型添加宏能力

    什么是ThinkSNS ? ThinkSNS(简称TS),一款全平台综合性社交系统,为国内外大中小企业和创业者提供社会化软件研发及技术解决方案,目前最新版本为ThinkSNS+(简称TS+).Thin ...

  3. SVN Trunk Tag Branch

    http://blog.csdn.net/vbirdbest/article/details/51122637

  4. jquery jtemplates.js模板渲染引擎的详细用法第一篇

    jquery jtemplates.js模板渲染引擎的详细用法第一篇 Author:ching Date:2016-06-29 jTemplates是一个基于JQuery的模板引擎插件,功能强大,有了 ...

  5. .NET Core中Circuit Breaker

    谈谈Circuit Breaker在.NET Core中的简单应用 前言 由于微服务的盛行,不少公司都将原来细粒度比较大的服务拆分成多个小的服务,让每个小服务做好自己的事即可. 经过拆分之后,就避免不 ...

  6. openstack安装newton版本Glance部署(二)

    一.部署Glance 1.Glance 安装 [root@linux-node1 ~]#yum install openstack-glance python-glance python-glance ...

  7. MapReduce编程入门实例之WordCount:分别在Eclipse和Hadoop集群上运行

    上一篇博文如何在Eclipse下搭建Hadoop开发环境,今天给大家介绍一下如何分别分别在Eclipse和Hadoop集群上运行我们的MapReduce程序! 1. 在Eclipse环境下运行MapR ...

  8. Column 'xxx' in field list is ambiguous

    一 其实看一下ambiguous的翻译就好了 一开始我觉得是含糊什么的,后来找了下才知道应该是双关... 二 所以翻译过来就是 : 列'XX'在字段列表中双关 其实就是两张表有相同的字段,但是使用时, ...

  9. 树莓派2安装Xware实现迅雷远程下载

    首先,远程功能很实用,尤其是基于迅雷的,现在国内的下载基本上迅雷只手遮天,别的工具友好程度不理想,这是对于我这种小白来说. 首先,我的树莓派系统不是原生的,我烧写的是ubuntu16,没有桌面,没有多 ...

  10. echarts使用中的那些事儿( 三)

    饼图上的那些字与下面说明性的文字有些重合,该怎么缩小圆形的大小呢,还有它的位置,怎么让它向上一些或者向下一些: 有以下两个属性可以解决问题: radius : '55%', ------------这 ...