位置: IT常识 - 正文

Vue Element UI 中 el-table 树形数据 tree-props 多层级使用避坑

编辑:rootadmin
Vue Element UI 中 el-table 树形数据 tree-props 多层级使用避坑

推荐整理分享Vue Element UI 中 el-table 树形数据 tree-props 多层级使用避坑,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

实现效果: element官网提示设置tree-props为{children: ‘children’,hasChildren: ‘hasChildren’},data数据需要设置children和hasChildren属性,row-key也绑定了数据的唯一值变量id,但是树形结构的第三级就是出不来

如图

可以看到只有第二级,第三级并没有,于是查看了数据格式,和官方要求的也是一样的呢,但是第三层级就是不展示

最后发现

在el-table中,支持树类型的数据的显示。当 row 中包含 children 字段时,被视为树形数据。渲染树形数据时,必须要指定 row-key。支持子节点数据异步加载。

Vue Element UI 中 el-table 树形数据 tree-props 多层级使用避坑

设置 Table 的 lazy 属性为 true 与加载函数 load 。通过指定 row 中的 hasChildren 字段来指定哪些行是包含子节点。children 与 hasChildren 都可以通过 tree-props 配置。

default-expand-all属性表示默认展开,不需要展开可以删除。row-key="id" 和 row里面的属性有children字段(即数据里面需要有children字段) 是必须的,:tree-props="{children: ‘children’,hasChildren: ‘hasChildren’}可有可无。

如果不是懒加载的话,后端不要设置hasChildren 这个属性,要不然树形不能显示;如果是懒加载,则需要设置hasChildren字段。

错误代码: 因为我的数据不是懒加载,所以不需要添加后面的 hasChildren: 'hasChildren' 配置 并且在组装数据格式时,也不需要加上 hasChildren=true / hasChildren=false 的字段

完整代码:

<!--表格渲染--> <el-table :header-cell-style="{ color: '#FFF', background: '#333' }" :cell-style="{ color: '#FFF', background: '#333' }" row-key="id" :data="tableData" style="width: 100%" :default-sort="{ prop: '', order: '' }" @sort-change="sortChange" :tree-props="{ children: 'children' }" > <template slot="empty"> <span style="color: #969799">{{ $t("NeoLight.empty") }}</span> </template> <el-table-column prop="barcode" :sortable="true" :label="$t('NeoLight.barcodeNo')" width="180" /> <el-table-column prop="partNumber" :sortable="true" label="料号" width="150" /> <el-table-column prop="warehouseCode" :sortable="true" label="库别" width="150" /> <el-table-column prop="batch" :sortable="true" :label="$t('barcode.batch')" /> <el-table-column prop="provider" :sortable="true" :label="$t('storagePos.providerNumber')" /> <el-table-column prop="posName" :sortable="true" :label="$t('NeoLight.storageNo')" /> <el-table-column prop="dateCode" :sortable="true" label="DC" /> <el-table-column prop="reelAmount" :sortable="true" label="卷数" /> <el-table-column prop="amount" :sortable="true" :label="$t('NeoLight.amount')" /> <el-table-column prop="firstPutInDate" :sortable="true" :label="$t('NeoLight.firstPutInDate')" /> <el-table-column prop="putInDate" :sortable="true" :label="$t('NeoLight.putInDate')" /> </el-table>

接口返回的数据 为 二级 数据格式 但是table表格中要展示 三个层级 需要前端自己来处理 组装需要的格式 (有和我一样的小伙伴,可以让后端组装好格式返回噢)

let list = [ {canCheckOutTime: 1669613688280enabled: truegroupId: ""groupName: ""h: 8humidity: ""id: "21"labelId: ""labelName: ""posName: "C1"priority: 1storageId: "1"temperature: ""used: truew: 7warmPos: false}, { barcode: { amount: 23000, barcode: "CS0004", batch: "", children: [ { amount: 3000, barcode: "M150171314022J1RV", batch: "A436105244", createDate: "2022-12-01 15:55:32", dateCode: "2209", firstPutInDate: "2022-12-01 15:55:33", fullCode: "152S01563-017131|A436105244-2209|3000|M150171314022J1RV|TAIYO|4101546111011J1007FS", height: 8, id: "92", initialAmount: 0, labelAmount: 3000, maxStorageTime: 0, mixTime: 0, onlySingleOut: false, partNumber: "152S01563", partitionCount: 1, plateSize: 7, posName: "CS0004-1", provider: "TAIYO", providerNumber: "017131", putInDate: "2022-12-01 15:55:33", putInTime: 1669881333306, putInTimeStr: "2022-12-01 15:55:306", reelAmount: 1, relationCodes: [], size: "7X8", solder: false, solderStatus: 0, startWarmTime: -1, status: 0, thickness: "", type: 0, updateDate: "2022-12-01 15:55:33", used: false, usedCount: 0, warehouseCode: "W10B", warmTime: 0, }, { amount: 10000, barcode: "A1179700142220JB6S", batch: "TPA2233000KP", createDate: "2022-12-01 15:56:01", dateCode: "2022080", firstPutInDate: "2022-12-01 15:56:02", fullCode: "118S0176-797001|TPA2233000KP-20220807|10000|A1179700142220JB6S|CYNTEC|TPA2233000KP0000JB6S", height: 8, id: "95", initialAmount: 0, labelAmount: 10000, maxStorageTime: 0, mixTime: 0, onlySingleOut: false, partNumber: "118S0176", partitionCount: 2, plateSize: 7, posName: "CS0004-2", provider: "CYNTEC", providerNumber: "797001", putInDate: "2022-12-01 15:56:02", putInTime: 1669881362306, putInTimeStr: "2022-12-01 15:56:306", reelAmount: 1, relationCodes: [], size: "7X8", solder: false, solderStatus: 0, startWarmTime: -1, status: 0, thickness: "", type: 0, updateDate: "2022-12-01 15:56:02", used: false, usedCount: 0, warehouseCode: "W10B", warmTime: 0, }, { amount: 10000, barcode: "A1179700142220JB7L", batch: "TPA2233000KP", createDate: "2022-12-01 15:56:06", dateCode: "2022080", firstPutInDate: "2022-12-01 15:56:07", fullCode: "118S0176-797001|TPA2233000KP-20220807|10000|A1179700142220JB7L|CYNTEC|TPA2233000KP0000JB7L", height: 8, id: "96", initialAmount: 0, labelAmount: 10000, maxStorageTime: 0, mixTime: 0, onlySingleOut: false, partNumber: "118S0176", partitionCount: 2, plateSize: 7, posName: "CS0004-2", provider: "CYNTEC", providerNumber: "797001", putInDate: "2022-12-01 15:56:07", putInTime: 1669881367304, putInTimeStr: "2022-12-01 15:56:304", reelAmount: 1, relationCodes: [], size: "7X8", solder: false, solderStatus: 0, startWarmTime: -1, status: 0, thickness: "", type: 0, updateDate: "2022-12-01 15:56:07", used: false, usedCount: 0, warehouseCode: "W10B", warmTime: 0, }, ], createDate: "2022-12-01 15:55:05", firstPutInDate: "2022-12-01 16:29:47", fullCode: "CS0004-1", height: 8, id: "90", initialAmount: 0, labelAmount: 0, maxStorageTime: 0, mixTime: 0, onlySingleOut: false, outOpor: "", partNumber: "CS", partitionCount: 0, plateSize: 7, posName: "B19", putInDate: "2022-12-02 14:05:57", putInTime: 1669883387333, putInTimeStr: "2022-12-01 16:29:333", reelAmount: 3, relationCodes: [], size: "7X8", solder: false, solderStatus: 0, startWarmTime: -1, status: 0, subCodeList: [ ], thickness: "", type: 0, updateDate: "2022-12-02 14:05:57", used: true, usedCount: 4, usedDate: "2022-12-01 17:03:30", warmTime: 0, }, canCheckOutTime: 1669961157870, enabled: true, groupId: "", groupName: "", h: 8, humidity: "", id: "59", labelId: "", labelName: "", posName: "B19", priority: 19, storageId: "3", temperature: "", used: true, w: 7, warmPos: false, }, ];

可以看出

有的数据中没有children字段,有的有children字段 后端返回的树形结构数据一个二级数据格式,还需要前端处理,将children中每一条数据里的 posName 字段值取出来 并赋值给一个 barcode 的新字段 加上id 组成第二级数据,后端返回的 第二层级数据 作为 树形结构的 第三层级数据 使用

js代码 methods: { //从接口中获取数据 getList() { let data = this.query; outerInventory(data).then((res) => { this.pageLength = res.totalElements; this.changeTableJson(res.content); //调用组装数据方法 }); }, // 组装表格需要的数据格式 changeTableJson(listArray) { if (!this.isLoading) { const list2 = []; for (let jsonElement of listArray) { if (!jsonElement.barcode || !jsonElement.barcode.children) { list2.push(jsonElement); continue; } jsonElement.barcode.children = jsonElement.barcode.children.map( (item) => { if (item.barcode) { let temp = JSON.parse(JSON.stringify(item)); return { id: Math.floor(Math.random() * 1000) + "", barcode: item.posName, children: [temp], }; } } ); list2.push(jsonElement.barcode); } this.tableData = list2; this.isLoading = true; console.log(list2); } },}三级树形结构 官方例子<el-table :data="tableData1" style="width: 100%" row-key="id" :tree-props="{children: 'children'}"> <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>data() { return { tableData1: [{ id: 1, date: '2016-05-02', name: '王小虎', address: '上海市普陀区金沙江路 1518 弄' }, { id: 2, date: '2016-05-04', name: '王小虎', address: '上海市普陀区金沙江路 1517 弄', children: [ { id: 31, date: '2020-05-01', name: '王小虎', address: '上海市普陀区金沙江路 1519 弄', children: [ { id: 33, date: '2020-05-32', name: '王小虎', address: '上海市普陀区金沙江路 1519 弄' } ] }, { id: 32, date: '2020-05-32', name: '王小虎', address: '上海市普陀区金沙江路 1519 弄', children: [ { id: 34, date: '2020-05-32', name: '王小虎', address: '上海市普陀区金沙江路 1519 弄' } ] } ] }, { id: 3, date: '2016-05-01', name: '王小虎', address: '上海市普陀区金沙江路 1519 弄', }, { id: 4, date: '2016-05-03', name: '王小虎', address: '上海市普陀区金沙江路 1516 弄' }] } },实现效果

本文链接地址:https://www.jiuchutong.com/zhishi/297447.html 转载请保留说明!

上一篇:常见浏览器兼容性问题及解决办法总结(常见浏览器兼容软件)

下一篇:06_HTML_表单提交的细节(submit提交按钮的使用细节)(html 提交表单)

  • 华为p50怎么关闭hd(华为p50怎么关闭纯净模式)

    华为p50怎么关闭hd(华为p50怎么关闭纯净模式)

  • 微信如何查看未领取红包金额(微信如何查看未领取的红包)

    微信如何查看未领取红包金额(微信如何查看未领取的红包)

  • word怎么批量替换文字(word怎么批量替换不同内容)

    word怎么批量替换文字(word怎么批量替换不同内容)

  • 荣耀智慧屏x1是什么材质的屏幕呢(荣耀智慧屏x1是va还是ips)

    荣耀智慧屏x1是什么材质的屏幕呢(荣耀智慧屏x1是va还是ips)

  • 淘宝app怎么看等级(淘宝app如何查看淘宝等级)

    淘宝app怎么看等级(淘宝app如何查看淘宝等级)

  • 苹果11屏幕摔碎了怎么办(苹果11屏幕摔碎了原图)

    苹果11屏幕摔碎了怎么办(苹果11屏幕摔碎了原图)

  • 苹果手机闹钟声音大小怎么调(苹果手机闹钟声音大小在哪里)

    苹果手机闹钟声音大小怎么调(苹果手机闹钟声音大小在哪里)

  • 查看共享位置会提醒吗(共享位置打开了,谁可以看到)

    查看共享位置会提醒吗(共享位置打开了,谁可以看到)

  • 为什么苹果官网没有苹果xsmax了(为什么苹果官网比京东自营贵那么多)

    为什么苹果官网没有苹果xsmax了(为什么苹果官网比京东自营贵那么多)

  • 微信留言入选为精选留言有啥用(微信留言入选是谁选的)

    微信留言入选为精选留言有啥用(微信留言入选是谁选的)

  • 为什么在快手上评论了表情包但没显示出来(为什么在快手上设置的动态壁纸没有声音)

    为什么在快手上评论了表情包但没显示出来(为什么在快手上设置的动态壁纸没有声音)

  • 微信怎么发狗头表情(微信发狗头是什么意思)

    微信怎么发狗头表情(微信发狗头是什么意思)

  • 华为typec能充ipad pro么(华为typec能充苹果电脑吗)

    华为typec能充ipad pro么(华为typec能充苹果电脑吗)

  • 华为nova7se支持无线充电吗(华为nova7se支持红外线功能吗)

    华为nova7se支持无线充电吗(华为nova7se支持红外线功能吗)

  • 联想笔记本屏幕倒过来了怎么办(联想笔记本屏幕突然变暗了怎么恢复)

    联想笔记本屏幕倒过来了怎么办(联想笔记本屏幕突然变暗了怎么恢复)

  • 耳机usb接口和圆孔接口的区别(耳机usb接口什么样)

    耳机usb接口和圆孔接口的区别(耳机usb接口什么样)

  • 拒收是拉黑还是删除(拒收是拉黑还是册除)

    拒收是拉黑还是删除(拒收是拉黑还是册除)

  • designed by vivo是啥意思(designed by vivo是什么牌子)

    designed by vivo是啥意思(designed by vivo是什么牌子)

  • 阿里保证金怎么退(阿里的保证金)

    阿里保证金怎么退(阿里的保证金)

  • 苹果8支持无线充电吗(苹果8支持无线反向充电吗)

    苹果8支持无线充电吗(苹果8支持无线反向充电吗)

  • 怎么取消ipad微信登录(怎么关闭ipad微信)

    怎么取消ipad微信登录(怎么关闭ipad微信)

  • 苹果x相机怎么关闭镜像(苹果x相机怎么不显示1x)

    苹果x相机怎么关闭镜像(苹果x相机怎么不显示1x)

  • 苹果手机为什么突然出现激活锁(苹果手机为什么打不开wifi开关)

    苹果手机为什么突然出现激活锁(苹果手机为什么打不开wifi开关)

  • 手机号怎么买(不实名的手机号怎么买)

    手机号怎么买(不实名的手机号怎么买)

  • 资本公积怎么核实
  • 发票抬头类型怎么选 个人不能报销吗
  • 一般纳税人增值税申报操作流程
  • 个体工商户发票额度
  • 个人劳务费 税
  • 一般纳税人企业所得税税率
  • 企业年度财务报表主要包括
  • 进项税额计入其他应付款是什么意思
  • 小规模纳税人是个体户吗
  • 新准则下怎么调整长期股权投资损益调整
  • 价外补贴需要交增值税吗
  • 交车辆购置税需要开车去吗
  • 银行借款的利息支出属于什么会计要素
  • 购买原材料已付款怎么记账
  • 进项税过期不抵扣怎么写会计分录?
  • 转让金融资产的税率
  • 对外支付佣金代扣代缴
  • 个人所得税期末为负数审计调整
  • 外籍个税起征点
  • 预收培训费怎么确认增值税
  • linux怎么添加命令
  • 增值税发票和进项发票什么意思
  • 固态硬盘如何接入电脑
  • 收到厂家赠送的产品
  • 电脑如何进入bios设置
  • 融资中的未确认利息
  • 签合同要注意些什么
  • 【2023亲测可用】JS 获取电脑本地IP 和 电脑网络IP(外网IP|公网IP)
  • 个人所得税通过扣缴义务人申报
  • phpwechat
  • 常用的php操作mysql的函数有哪些
  • idea配置meaven
  • 驱动开发函数详解
  • 电商后台管理系统简介
  • php的序列化操作生成的哪种格式
  • 小规模企业逾期是微信扫码付款吗
  • 对公账户的资金怎么转出
  • 瀑布流样式
  • phpcms怎么样
  • 递延收益为什么是递延所得税资产
  • 增值税品种
  • 营改增后的劳务费怎么开
  • 新会计准则规定
  • 普通发票能做进项吗
  • sqlserver获取uuid
  • 分派现金股利处理
  • 个税申报哪些可以减免
  • 破产清算应收账款怎么评估
  • 企业汇算清缴必须要做审计吗
  • 固定资产正常报废与非正常报废的会计处理基本相同
  • 因管理不善的材料怎么办
  • 自产的产品用于管理部门
  • 购入无形资产属于资产吗
  • 在我国土地使用权分为哪几类
  • 没有水电费发票可以入账吗
  • 转账手续费怎么入账
  • 代扣代缴增值税申报期限
  • 固定资产改变用途折旧处理
  • 财务大写金额书写样板
  • 委托设置什么意思
  • Windows Server 2008域环境下组策略两例应用
  • fedora最新版本
  • 微软每月补丁更新一般于什么时间发布
  • mac文件权限
  • win10系统资源管理器怎么重新安装
  • win7任务管理器怎么调回原来样子
  • win7如何打开浏览器
  • android app 开发框架
  • 详解九章算法
  • java 视频教程
  • android动画实现方式
  • 四川省税务局发票查询
  • 河东区地税局上班时间
  • 公司买的保险怎么查询保单明细
  • 供热企业税收优惠政策执行情况
  • 山东水利建设基金减免政策
  • 副局长是由局长任命的吗
  • 网上增值税发票验旧
  • 职业年金利息计入哪个科目里面
  • 珠海斗门井岸镇邮编
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设