完整教程:<el-table>构建树形结构

news/2025/10/5 21:39:31/文章来源:https://www.cnblogs.com/ljbguanli/p/19127076

完整教程:<el-table>构建树形结构

最佳实践

el-table实现树形结构主要依靠row-keytree-props来实现的。
? 无论是el-table实现的树形结构还是el-tree组件都是绑定的树形结构的数据,因此如果数据是扁平的话,需要进行树化。

代码

<template><div><el-table:data="tableData"style="width: 100%;margin-bottom: 20px;"row-key="id"borderdefault-expand-all:tree-props="{children: 'children', hasChildren: 'hasChildren'}"><el-table-columnprop="date"label="日期"sortablewidth="180"></el-table-column><el-table-columnprop="name"label="姓名"sortablewidth="180">
</el-table-column>
<el-table-columnprop="address"label="地址">
</el-table-column>
</el-table>
</div>
</template>
<script>
export
default {
data(
) {
return {
tableData: [{
id: 1
,
date: '2016-05-02'
,
name: '王小虎'
,
address: '上海市普陀区金沙江路 1518 弄'
}
,
{
id: 2
,
date: '2016-05-04'
,
name: '王小虎'
,
address: '上海市普陀区金沙江路 1517 弄'
}
,
{
id: 3
,
date: '2016-05-01'
,
name: '王小虎'
,
address: '上海市普陀区金沙江路 1519 弄'
,
children: [{
id: 31
,
date: '2016-05-01'
,
name: '王小虎'
,
address: '上海市普陀区金沙江路 1519 弄'
}
,
{
id: 32
,
date: '2016-05-01'
,
name: '王小虎'
,
address: '上海市普陀区金沙江路 1519 弄'
}]
}
, {
id: 4
,
date: '2016-05-03'
,
name: '王小虎'
,
address: '上海市普陀区金沙江路 1516 弄'
}]
}
}
,
methods: {
}
,
}
</script>
当前视图

可以看到树形结构默认是打开的

在这里插入图片描述

核心属性

  • default-expand-all:树形结构打开还是关闭。
    关闭可以通过删除default-expand-all:default-expand-all = 'false'对属性值进行动态绑定,并将值置为false
  • children:指定子节点数据在父节点对象中的字段名,这里是 children 。
    也可以修改为其它名称,但是两处都需要进行修改
  • hasChildren:这个属性是非必须的,需要进行懒加载的时候才需要用到它。
    hasChildren需要和lazy属性、load属性来实现懒加载,lazy为true时,load方法才会生效。hasChildren属性和children属性相同,也可以修改名称。

懒加载

只加载需要展示的数据,其它数据等用户主动点击才会请求后端拿取。

代码

<template><div><el-table:data="tableData1"style="width: 100%"row-key="id"borderlazy:load="load":tree-props="{ children: 'children', hasChildren: 'hasChildren' }"><el-table-column prop="date" label="日期" width="180"></el-table-column><el-table-column prop="name" label="姓名" width="180"></el-table-column><el-table-column prop="address" label="地址"></el-table-column></el-table>
</div>
</template>
<script>
export
default {
data(
) {
return {
tableData: [{
id: 1
,
date: '2016-05-02'
,
name: '王小虎'
,
address: '上海市普陀区金沙江路 1518 弄'
}
,
{
id: 2
,
date: '2016-05-04'
,
name: '王小虎'
,
address: '上海市普陀区金沙江路 1517 弄'
}
,
{
id: 3
,
date: '2016-05-01'
,
name: '王小虎'
,
address: '上海市普陀区金沙江路 1519 弄'
,
children: [{
id: 31
,
date: '2016-05-01'
,
name: '王小虎'
,
address: '上海市普陀区金沙江路 1519 弄'
}
,
{
id: 32
,
date: '2016-05-01'
,
name: '王小虎'
,
address: '上海市普陀区金沙江路 1519 弄'
}]
}
, {
id: 4
,
date: '2016-05-03'
,
name: '王小虎'
,
address: '上海市普陀区金沙江路 1516 弄'
}]
,
tableData1: [{
id: 1
,
date: '2016-05-02'
,
name: '王小虎'
,
address: '上海市普陀区金沙江路 1518 弄'
}
, {
id: 2
,
date: '2016-05-04'
,
name: '王小虎'
,
address: '上海市普陀区金沙江路 1517 弄'
}
, {
id: 3
,
date: '2016-05-01'
,
name: '王小虎'
,
address: '上海市普陀区金沙江路 1519 弄'
,
hasChildren: true
}
, {
id: 4
,
date: '2016-05-03'
,
name: '王小虎'
,
address: '上海市普陀区金沙江路 1516 弄'
}]
}
}
,
methods: {
load(row, treeNode, resolve
) {
// 查找对应的父节点
const findChildren = (data, id
) =>
{
for (
let item of data) {
console.log(item.id)
;
if (item.id === id) {
console.log(item.id)
;
return item.children || []
;
}
}
return []
;
}
;
if (treeNode) {
const children = findChildren(
this.tableData, row.id)
;
resolve(children)
;
}
else {
resolve([]
)
;
}
}
}
,
}
</script>

效果图

在这里插入图片描述

到这里el-table加载树形结构就结束了。☺️

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/928763.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

集团企业网站建设文案wordpress图片不清晰

C、Java、JavaScript和python几个语句的对比介绍 C、Java、JavaScript和python语言的for语句 C、Java和JavaScript的for语句的语法类似如下&#xff1a; for (初始条件; 循环条件; 循环后操作) { // 循环体代码 } 初始条件是在进入循环之前执行的语句&#xff0c;初始化循环…

如何在markdown中插入折叠框

rt,我使用的方法比较朴素简单。 直接在markdown中写入html的标签即可,如下: <details> <summary>标题</summary> 内容 </details>就会呈现以下效果:标题 内容

ESP32-C3 Vscode+ESP-IDF开发环境搭建 保姆级教程 - 教程

ESP32-C3 Vscode+ESP-IDF开发环境搭建 保姆级教程 - 教程pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas…

网站数据模版收费网站推广

为什么80%的码农都做不了架构师&#xff1f;>>> 反正每次来做一个不熟悉的东西&#xff0c;就是各种的search ,前一次去做过一个apache的东西&#xff0c;各种蛋疼&#xff0c;各种不能用。好多的东西也是比较旧了的咯。 这次结合前辈的各种东借西拿&#xff0c;总…

CF2115 VP 记录

CF2115 Div1 B 比较人类智慧. 后面操作会覆盖前面的,考虑对序列 \(b\) 构造一种具有必要性的操作使得满足题目限制,因为一个重要事实是序列 \(a\) 并不唯一,只要对于任意位置,在被覆盖前没有覆盖其他位置的操作,或…

设计网站教程wordpress根目录没有.htaccess

近几年&#xff0c;我国潮玩市场经历了爆发式的发展阶段&#xff0c;尤其是盲盒市场屡创新高&#xff01;盲盒商品主打IP衍生品、周边等具有收藏价值的商品&#xff0c;深受市场的追捧&#xff0c;满足了不同年龄群体的需求。面对盲盒的蓝海市场&#xff0c;众多的品牌也纷纷加…

基于springboot的医护人员排班平台设计与构建(源码+文档+部署讲解)

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

做网站的软件公司中国室内设计师联盟

&#x1f34e;个人博客&#xff1a;个人主页 &#x1f3c6;个人专栏&#xff1a;日常聊聊 ⛳️ 功不唐捐&#xff0c;玉汝于成 目录 前言 正文 一、整体介绍 对话系统&#xff08;Chat&#xff09; 自主代理&#xff08;Agent&#xff09; 二、技术对比 技术差异 优…

2-SAT模板

洛谷p4782 #include<iostream> #include<vector> #include<algorithm> using namespace std; const int N=2e6+10; int n,m; int dfn[N],low[N],stk[N],instk[N],tot,cnt,scc[N],top; vector<int…

千度网站wordpress加联系方式

LntonAIServer作为一款智能视频监控平台&#xff0c;集成了多种先进的视频质量诊断功能&#xff0c;其中包括抖动检测和过暗检测算法。这些算法对于提升视频监控系统的稳定性和图像质量具有重要意义。 以下是对抖动检测算法和过暗检测算法的应用场景及优势的详细介绍。 一、L…

票务网站策划书手加工外包加工网

点击下方卡片&#xff0c;关注“小白玩转Python”公众号 简介 在计算机视觉领域&#xff0c;准确地测量图像相似性是一项关键任务&#xff0c;具有广泛的实际应用。从图像搜索引擎到人脸识别系统和基于内容的推荐系统&#xff0c;有效比较和查找相似图像的能力非常重要。Siames…

lab5

流程图 到了这个lab5才算是真正看清除了整个lab的样子, 之前还一直纳闷lab2好像没什么用… 这个系统的核心思想是 分而治之。通过将整个键空间划分为多个分片(Shard),并将这些分片分配给不同的、可独立运行的服务器…

lab4

架构 架构图:简单说, 我们要建立的KV数据库是位于raft层之上的, 或者说我们的KV数据库使用了raft库。客户端(就是代码中的clerk)调用应用层(server)的RPC,应用层收到RPC之后,会调用Start函数,Start函数会立即返回…

公司网站要使用我个人的信息备案如何用表格做网站

7-10 解一元二次方程 分数 20 全屏浏览 切换布局 作者 李祥 单位 湖北经济学院 请编写程序&#xff0c;解一元一次方程 ax2bxc0 。 已知一元二次方程的求根公式为&#xff1a; 要求&#xff1a; 若 a0&#xff0c;则为一元一次方程。 若 b0&#xff0c;则方程有唯一解&…

公司关于网站建设的通知春风摩托车官方网

API作用使用场景curl localhost:9200/_cluster/health?pretty查看ES健康状态curl localhost:9200/_cluster/settings?pretty查看ES集群的设置其中persistent为永久设置&#xff0c;重启仍然有效&#xff1b;trainsient为临时设置&#xff0c;重启失效curl localhost:9200/_ca…

某中心2026年推出1111个技术实习岗位

某中心宣布2026年将提供1111个实习岗位,涵盖工程、产品管理、研究等技术领域。实习生将参与影响数百万互联网用户的实际项目,并享受包括无服务器应用平台在内的免费技术资源。某中心承诺2026年提供1111个实习机会 某…

NumPy广播:12个技巧替代循环,让数组计算快40倍

写Python数据处理代码时反复用for循环?这其实是在给程序性能交"税"。NumPy的广播(broadcasting)机制能让你摆脱这种困境——代码量更少,执行更快,关键是思维方式从"逐个迭代"转向"整体形状…

网站建设费用如何做账务处理wordpress 修改页面内容

198. 打家劫舍&#xff08;题目链接&#xff1a;力扣&#xff08;LeetCode&#xff09;官网 - 全球极客挚爱的技术成长平台&#xff09; 思路&#xff1a;dp题除背包外的另外一类题目&#xff0c;重点不在于看前面的情况&#xff0c;而在于考虑本节点的情况。一种情况&#xf…

川土微变频器应用分享

川土微电子在变频器领域的应用主要体现在隔离接口、隔离运放和隔离驱动产品上的解决方案上,其产品通过高可靠性和定制化设计,有效提升了变频器的信号传输安全性和系统稳定性‌了。以下是具体应用场景及产品方案: 一…

wordpress单页导航模版建设网站优化

目录 前言1. 公共逻辑2. 单个删除3. 批量删除 前言 由于近期慢慢转全栈&#xff0c;后续会以前后端的形式讲解 对应的Avue相关知识推荐阅读&#xff1a;【vue】avue-crud表单属性配置&#xff08;表格以及列&#xff09;对应后端知识推荐阅读&#xff1a;java框架 零基础从入…