当前位置: 首页 > news >正文

SAPUI5 树形表格TreeTable示例

 页面效果可展开折叠

view/TreeTable.view.xml

<mvc:ViewcontrollerName="your.path.process.TreeTable"xmlns="sap.ui.table"xmlns:m="sap.m"xmlns:mvc="sap.ui.core.mvc"><TreeTableid="treeTable"selectionMode="Single"visibleRowCount="10"enableColumnReordering="false"expandFirstLevel="true"rows="{path: '/Nodes',parameters: {arrayNames: ['Nodes']}}"><columns><Column label="Description" width="200px"><template><m:Text text="{Description}" wrapping="false" /></template></Column><Column label="HierarchyLevel" width="120px"><template><m:Text text="{HierarchyLevel}" wrapping="false" /></template></Column><Column label="NodeID" width="100px"><template><m:Text text="{NodeID}" wrapping="false" /></template></Column><Column label="ParentNodeID" width="120px"><template><m:Text text="{ParentNodeID}" wrapping="false" /></template></Column></columns></TreeTable>
</mvc:View>

controller/TreeTable.controller.js

sap.ui.define(["sap/ui/core/mvc/Controller",'sap/ui/model/json/JSONModel','your.path/utils/common'
], function(Controller, JSONModel, common) {"use strict";return Controller.extend("your.path.controller.process.TreeTable", {onInit: function() {let me = this,oView = me.getView();// 构建树形结构数据let hierarchicalData = this._buildHierarchicalData();let oModel = new JSONModel(Object.assign({Nodes: hierarchicalData}, common.getDeCodeUrlObj()));oView.setModel(oModel);},_buildHierarchicalData: function() {// 原始平铺数据let flatData = [{"NodeID": 1,"Description": "1","ParentNodeID": null,},{"NodeID": 2,"Description": "2","ParentNodeID": null,},{"NodeID": 3,"Description": "3","ParentNodeID": null,},{"NodeID": 4,"Description": "1.1","ParentNodeID": 1,},{"NodeID": 5,"Description": "1.2","ParentNodeID": 1,},{"NodeID": 6,"Description": "1.2.1","ParentNodeID": 5,},{"NodeID": 7,"Description": "1.2.2","ParentNodeID": 5,},{"NodeID": 8,"Description": "2.1","ParentNodeID": 2,},{"NodeID": 9,"Description": "2.2","ParentNodeID": 2,},{"NodeID": 10,"Description": "2.3","ParentNodeID": 2,},{"NodeID": 11,"Description": "3.1","ParentNodeID": 3,},{"NodeID": 12,"Description": "3.1.1","ParentNodeID": 11,},{"NodeID": 13,"Description": "3.1.1.1","ParentNodeID": 12,},{"NodeID": 14,"Description": "3.1.1.2","ParentNodeID": 12,},{"NodeID": 15,"Description": "3.1.1.3","ParentNodeID": 12,},{"NodeID": 16,"Description": "3.1.1.4","ParentNodeID": 12,}];// 将平铺数据转换为树形结构return this._convertToHierarchical(flatData);},_convertToHierarchical: function(flatData) {let hierarchicalData = [];let lookup = {};// 创建查找表flatData.forEach(function(item) {lookup[item.NodeID] = Object.assign({}, item);lookup[item.NodeID].Nodes = [];});// 构建层级关系flatData.forEach(function(item) {if (item.ParentNodeID === null) {// 根节点hierarchicalData.push(lookup[item.NodeID]);} else {// 子节点if (lookup[item.ParentNodeID]) {lookup[item.ParentNodeID].Nodes.push(lookup[item.NodeID]);}}});return hierarchicalData;}});
});

在manifest中配置路由

...{"pattern": "TreeTable","name": "TreeTable","target": ["TreeTable"]}
...

http://www.dtcms.com/a/299473.html

相关文章:

  • Spring AI(14)——文本分块优化
  • java之23种设计模式
  • 设计模式:Memento 模式详解
  • 简单实现支付密码的页面及输入效果
  • 面条式代码(Spaghetti Code)
  • Java高级之基于Java Attach与Byte-Buddy实现SQL语句增强
  • JWT安全机制与最佳实践详解
  • Linux 系统调用详解:操作文件的常用系统调用
  • Vulnhub jangow-01-1.0.1靶机渗透攻略详解
  • 自定义定时任务功能详解
  • MySQL 表的约束
  • 【面板数据】中国A股上市公司制造业智能制造数据集(1992-2024年)
  • 基于图神经网络的星间路由与计算卸载强化学习算法设计与实现
  • java实现一个方法,isTure则程序继续往下,为false则return的链式写法
  • 零基础学习性能测试第三章:jmeter线程组组合
  • LeetCode|Day26|191. 位 1 的个数|Python刷题笔记
  • Java学习|黑马笔记|Day23】网络编程、反射、动态代理
  • AI+预测3D新模型百十个定位预测+胆码预测+去和尾2025年7月26日第150弹
  • 在Power Automate Desktop中执行PowerShell获取SharePoint online某个文件夹的用户权限列表
  • SAP ABAP的数据通过调用泛微Restful API同步数据到OA建模表
  • 学习日志19 python
  • pytest中的rerunfailures的插件(失败重试)
  • 在 Scintilla 中为 Squirrel 语言设置语法解析器的方法
  • 【Kubernetes】使用StatefulSet进行的资源调度,扩缩容,更改配置到版本回滚,三种配置更新方式
  • c#中让图片显示清晰
  • 三、平衡桥电路
  • 060_泛型擦除与边界限定
  • MySQL数据库SQL语句进阶篇——连接查询与子查询详解
  • Traffic Lights set的使用
  • CSS变量与Houdini自定义属性:解锁样式编程新维度