Element-UI定制化Tree 树形控件

1.复制

说明:复制Tree树形控件。

javascript 复制代码
<script>
export default {
  data() {
    return {
      data: [{
        label: '一级 1',
        children: [{
          label: '二级 1-1',
          children: [{
            label: '三级 1-1-1'
          }]
        }]
      }, {
        label: '一级 2',
        children: [{
          label: '二级 2-1',
          children: [{
            label: '三级 2-1-1'
          }]
        }, {
          label: '二级 2-2',
          children: [{
            label: '三级 2-2-1'
          }]
        }]
      }, {
        label: '一级 3',
        children: [{
          label: '二级 3-1',
          children: [{
            label: '三级 3-1-1'
          }]
        }, {
          label: '二级 3-2',
          children: [{
            label: '三级 3-2-1'
          }]
        }]
      }],
      defaultProps: {
        children: 'children',
        label: 'label'
      }
    };
  },
  methods: {
    handleNodeClick(data) {
      console.log(data);
    }
  }
};
</script>
<template>
<div>
  <h1>我是树形控件</h1>
  <el-tree :data="data" :props="defaultProps" @node-click="handleNodeClick"></el-tree>
</div>
</template>

<style scoped>

</style>

2.显示

3.图标

3.1新增图标

说明:每一个label前面都有一个定制图标

javascript 复制代码
<template>
<div>
  <h1>我是树形控件</h1>
  <el-tree :data="data" :props="defaultProps" @node-click="handleNodeClick">
      <span slot-scope="{ node, data }" style="align-items: center">
        <i class="icon-book">
          <img style="width: 20px;" src="../../gis/images/bookmark-one.png">
        </i>
        <span>{{node.label}}</span>
      </span>
  </el-tree>
</div>
</template>

或者

javascript 复制代码
<template>
<div>
  <h1>我是树形控件</h1>
  <el-tree class="custom-el-tree" :data="data" :props="defaultProps" @node-click="handleNodeClick">
    <template v-slot="{ node, data }">
    <span style="align-items: center">
      <i>
        <img style="width: 20px;" src="../../gis/images/bookmark-one.png">
      </i>
      <span>{{ node.label }}</span>
    </span>
    </template>
  </el-tree>
</div>
</template>

3.2修改默认图标

说明: 将默认箭头形式变成加号形式。

css 复制代码
<style scoped>
/* 加号*/
/deep/ .custom-el-tree .el-icon-caret-right:before {
  content: "\e6d9";
  font-size: 18px;
}

</style>

4.源码

javascript 复制代码
<script>
export default {
  data() {
    return {
      data: [{
        label: '一级 1',
        children: [{
          label: '二级 1-1',
          children: [{
            label: '三级 1-1-1'
          }]
        }]
      }, {
        label: '一级 2',
        children: [{
          label: '二级 2-1',
          children: [{
            label: '三级 2-1-1'
          }]
        }, {
          label: '二级 2-2',
          children: [{
            label: '三级 2-2-1'
          }]
        }]
      }, {
        label: '一级 3',
        children: [{
          label: '二级 3-1',
          children: [{
            label: '三级 3-1-1'
          }]
        }, {
          label: '二级 3-2',
          children: [{
            label: '三级 3-2-1'
          }]
        }]
      }],
      defaultProps: {
        children: 'children',
        label: 'label'
      }
    };
  },
  methods: {
    handleNodeClick(data) {
      console.log(data);
    }
  }
};
</script>
<template>
<div>
  <h1>我是树形控件</h1>
  <el-tree class="custom-el-tree" :data="data" :props="defaultProps" @node-click="handleNodeClick">
    <template v-slot="{ node, data }">
    <span style="align-items: center">
      <i>
        <img style="width: 20px;" src="../../gis/images/bookmark-one.png">
      </i>
      <span>{{ node.label }}</span>
    </span>
    </template>
  </el-tree>
</div>
</template>

<style scoped>
/* 加号*/
/deep/ .custom-el-tree .el-icon-caret-right:before {
  content: "\e6d9";
  font-size: 18px;
}

</style>
相关推荐
MXN_小南学前端几秒前
Vue + Quill:富文本的添加、传输、展示逻辑,以及 csReplyQuill 组件封装
前端·vue.js
XS0301061 分钟前
Java Web实现简易CRUD操作笔记
java·前端·笔记
Shadow(⊙o⊙)3 分钟前
qt内详解信号和槽的基本概念+实例演示
开发语言·前端·c++·qt·学习
qq_381338504 分钟前
Vue3 组合式函数设计模式:从基础封装到高级复用实战
前端·vue.js·设计模式
步十人4 分钟前
【CSS】基础一篇过
前端·css
回眸一笑吟离歌7 分钟前
edge浏览器更新后打开局域网服务报错:ERR_ADDRESS_UNREACHABLE
前端·edge
幽络源小助理10 分钟前
在线图片处理工具源码, 多功能编辑格式转换HTML单文件版
前端·html
humcomm13 分钟前
AI编程时代前端架构师的机遇和挑战
前端·架构·ai编程
adminwolf22 分钟前
自研企业微信SCRM系统源码独立部署(Golang+Vue.js)
前端·vue.js·企业微信
小短腿的代码世界23 分钟前
QwtPolar 与实时示波器级渲染优化:雷达图到示波器曲线的极限性能调优
前端·qt·架构·交互