使用效果



初始化加载顶层节点,点击各层的>加载该节点的子节点,加载后>标识去除不再重复加载。

前端代码

vue ant-design组件

  • tree-data,树节点,children方式或id、pid方式
  • load-data,展开节点事件,响应该事件加载子节点
<a-tree-select v-model:value="sample" :tree-data="sampleTreeData" :load-data="onLoadSampleTreeData"
style="width: 100%" allowClear treeDataSimpleMode
:dropdown-style="{ maxHeight: '400px', overflow: 'auto' }"
placeholder="请选择测试计划/样品" >
</a-tree-select>

定义interface

  • 异步加载通过id和pid匹配,因此没有children属性,替换为id何pid
  • 添加level便于后端识别,如果后端为一个表内的数据且通过id和pid或parentid关联则不需要
export interface TreeDataItem {
id: string | number;
pId: string | number;
value: string;
title: string;
isLeaf?: boolean;
level: string;
}

加载(跟节点)数据

调用后端查询数据并赋值给treeData,treeData绑定控件的treeData属性。

async function loadSampleTreeRootData() {
// loading.value = true
let params = {"level":"0"};
sampleTreeNode(params).then(result => {
console.log(result)
sampleTreeData.value = sampleTreeData.value.concat(result);
}).finally(() => {
});
// loading.value = false
}
loadSampleTreeRootData()

加载(节点的子节点)数据

响应控件的load-data事件,查询要展开节点的子节点数据,并合并到treeData中,控件会根据id和pid显示层级关系。

const onLoadSampleTreeData = (treeNode: any) => {
return new Promise((resolve: (value?: unknown) => void) => {
// console.log("node:");
// console.log(treeNode.dataRef)
const { id,level,value } = treeNode.dataRef;
// console.log("id:"+id);
// console.log("level:"+level);
// console.log("value:"+value);
setTimeout(() => {
let nextLevel = "1";
if(level=="1")nextLevel="2";
let params = {"level":nextLevel, "id":id};
sampleTreeNode(params).then(result => {
// console.log("result:");
// console.log(result);
sampleTreeData.value = sampleTreeData.value.concat(result);
}).finally(() => {
});
resolve();
}, 300);
});
};

后端代码

定义treeNodeVO

pId和isLeaf注解下,避免springMVC默认的序列化。

(默认序列化为pid\leaf)

@Data
public class PlantSampleTreeNodeVO {
//key
private String id;
// private long id; @JsonProperty("pId")
private String pId;
// private long pId; //树节点显示的内容
private String title; //默认根据此属性值进行筛选(其值在整个树范围内唯一)
private Object value; //是否是叶子节点
@JsonProperty("isLeaf")
private boolean isLeaf; //节点层级
private String level; }

controller提供数据

因为是异步加载,三个表的查询可在一个service中实现,或直接使用各自的treeNode的service。

@Override
public List<PlantSampleTreeNodeVO> getPlantSampleTreeNodeVO(String level, String id) {
List<PlantSampleTreeNodeVO> plantSampleTreeVONodeList = new ArrayList<>();
switch (level) {//顶级节点
case "0":
//查询所在班组,plant member
List<Plant> plantList = plantService.list();
for (Plant plant : plantList) {
//创建顶层树/节点
PlantSampleTreeNodeVO plantNode = new PlantSampleTreeNodeVO();
// System.out.println(plant.getId());
// System.out.println(Long.parseLong(plant.getId()));
// System.out.println(Long.valueOf(plant.getId()).longValue());
// plantNode.setId(Long.parseLong(plant.getId()));
plantNode.setId(plant.getId());
plantNode.setPId("0");//and-design tree指定的值
plantNode.setValue(plant.getId());
plantNode.setTitle(plant.getPlantName());
plantNode.setLeaf(false);//需根据业务逻辑判断是否有子节点,省略处理
plantNode.setLevel("0");
plantSampleTreeVONodeList.add(plantNode);
}
break;
case "1":
//查询班组相关的样品组模板
QueryWrapper<SampleGroupTemplate> sampleGroupTemplateQueryWrapper = new QueryWrapper<>();
sampleGroupTemplateQueryWrapper.eq("plantid",id);
List<SampleGroupTemplate> sampleGroupTemplateList = sampleGroupTemplateService.list(sampleGroupTemplateQueryWrapper);
//循环各样品组模板显示其下的测试计划/样品
for(SampleGroupTemplate sampleGroupTemplate: sampleGroupTemplateList){
//添加到树上
PlantSampleTreeNodeVO sampleGroupNode = new PlantSampleTreeNodeVO();
// sampleGroupNode.setId(Long.parseLong(sampleGroupTemplate.getId()));
sampleGroupNode.setId(sampleGroupTemplate.getId());
// sampleGroupNode.setPId(Long.parseLong(id));
sampleGroupNode.setPId(id);
sampleGroupNode.setValue(sampleGroupTemplate.getId());
sampleGroupNode.setTitle(sampleGroupTemplate.getSampleGroupName());
sampleGroupNode.setLeaf(false);
sampleGroupNode.setLevel("1");
plantSampleTreeVONodeList.add(sampleGroupNode);
}
break;
case "2":
//查询样品组模板显示其下的测试计划/样品
QueryWrapper<SgtSample> sampleQueryWrapper = new QueryWrapper<>();
sampleQueryWrapper.eq("templateid",id);
List<SgtSample> sampleList = this.list(sampleQueryWrapper);
//循环各样品
for(SgtSample sample: sampleList) {
PlantSampleTreeNodeVO sampleNode = new PlantSampleTreeNodeVO();
// sampleNode.setId(Long.parseLong(sample.getId()));
sampleNode.setId(sample.getId());
// sampleNode.setPId(Long.parseLong(id));
sampleNode.setPId(id);
sampleNode.setValue(sample.getId());
sampleNode.setTitle(sample.getSampleName());
sampleNode.setLeaf(true);//叶子节点
sampleNode.setLevel("2");
plantSampleTreeVONodeList.add(sampleNode);
}
break;
}
return plantSampleTreeVONodeList;
}

最新文章

  1. Sass中文乱码问题(手动编译和watch编译)
  2. Maven配置不成功
  3. u盘文件系统故障的修复方法
  4. jstl标签库基础教程及其使用代码(一)。
  5. UVa 1402 Runtime Error 伸展树
  6. HttpRequest中常见的四种ContentType【转载】
  7. 翻译 | 玩转 React 表单 —— 受控组件详解
  8. Javascript高级编程学习笔记(88)—— Canvas(5)绘制文本
  9. MySql 5.7.23安装
  10. Hbase 与mapreduce结合
  11. Every-SG游戏
  12. 由swap引发的关于按值传递和引用传递的思考与总结
  13. 723 if while for
  14. Doxygen生成C++中文文档配置注意事项
  15. S11 day 96 RestFramework 之认证权限
  16. Java面试题大汇总
  17. 选择Memcached还是Redis?
  18. Intellij IDEA:maven的本地仓库问题
  19. 生成验证码程序C#
  20. Carte上面的作业1、2天就会丢失的问题

热门文章

  1. AS之去掉顶部标题栏
  2. PAT B1014 福尔摩斯约会
  3. Ubu18安装RabbitMQ
  4. Metalama简介1. 不止是一个.NET跨平台的编译时AOP框架
  5. 计算机编码规则之:Base64编码
  6. jquery的常用API
  7. Codeforces Round #762 (Div. 3), CDE
  8. python黑帽子(第二章)
  9. VMware虚拟机无法安装Win11解决方法 (暂时全网最全方案)
  10. 基于pgrouting的路径规划处理