当前位置:网站首页>【测试平台开发】十七、接口编辑页面实现下拉级联选择,绑定接口所属模块...
【测试平台开发】十七、接口编辑页面实现下拉级联选择,绑定接口所属模块...
2022-07-23 09:01:00 【把苹果咬哭的测试笔记】
基于 springboot+vue 的测试平台开发继续更新。
停更得有半年,最近待业家中没有理由不继续更新了。本来是打算做别的功能,但是我的重新调试环境的时候发现了bug,搞半天原来是因为没实现接口与模块的绑定,导致点击左侧模块树之后列表页就没数据。气死我了,那先来把这个坑填上。
先看一下最后的功能效果动图。

因为完善这个功能要涉及一些之前功能的改动,所以接下来以实际的开发修改过程来记录内容(源码获取在文末):
- 寻找级联组件
- 后端返回组件需要的数据内容
- 修改前端内容,使用级联组件
- 修改新增、编辑功能,保存选择的模块
- 修改编辑回显功能,显示对应节点
一、级联选择器组件
elementUI 官网,找到级联选择器组件。

查看组件的功能属性,发现可以满足我的需求:
- 悬停触发级联菜单
- 支持单独选择每一级
- 支持搜索节点
二、后端返回组件需要的数据
查看组件属性得知所需的数据内容,value用于存放选择的节点,注意这里存进去的是数组。而options就是数据源来,也是一个数组,里面的属性有:
- value,选择节点时候的赋值
- label,显示的节点文本内容
- children,子节点嵌套的内容

其实这里模块节点里要用的数据,就是左侧模块树的数据。

对于这个模块树我后端是有一个专门的接口返回的,所以我打算复用这个接口。思路就是当这个接口被请求的时候,我再把这个接口返回的数据赋值options即可。
但是用下来发现后端原接口是少了一个返回字段value,会导致选择的时候有bug,所以我修改了后端接口,增加一个字段的返回。

新增的字段里的值我使用模块id,不会重复。
F12看下修改后的接口返回,没问题。

三、前端使用级联组件
后端数据有了,下面改前端,找到编辑页面里的对应位置,原来的内容是我临时放置的一个下拉选择框(图中被注释部分),现在用级联组件的内容(红框部分)替换上去。

说一下用到的组件属性:
:show-all-levels="false": 输入框中是否显示选中值的完整路径,false就只显示最后一级。filterable: 是否可搜索选项,开启placeholder: 占位符,显示背景内容clearable:支持清空选项v-model: 绑定你选中的节点value 到某个字段上options: 后端接口返回的数据,存放在这个字段上:props:用到的一些其他配置选项@change:当选中节点变化时触发
{ expandTrigger: 'hover', checkStrictly: true },关于用到的2个 props,作用分别是:
- expandTrigger:次级菜单的展开方式,hover是鼠标悬停展开,我觉得比较方便。
- checkStrictly: 是否严格的遵守父子节点不互相关联,true 就可以支持任意一个节点的选择。
四、新增、编辑里保存选择的模块
我重新查看了前端点击保存按钮的代码,发现会判断此时是新增还是编辑,从而选择调用对应的新增或者修改方法。

进一步查看这2个方法,发现里面关于请求数据的处理都封装在另一个方法handleSaveRequest里。

找到方法了对应的模块id的字段,之前我没实现这个功能的时候,是写死了 0。
这里我前端做了一下处理,因为后端接口接收到参数是int,但是组件这里 value 是数组,通过在handleChange方法里加log打印,查看控制台里的返回便知。

这里我操作了2次,发现数组的最后一个是你选择的节点,所以我要取出这个最后一个节点用来请求后端接口,索引就是数组length-1。

本来以为这样就可以了,后来调试时候发现bug,最后发现新增和编辑的时候,还不能统一都这么处理。
因为新增的时候传入的是数组,但是编辑的时候就只是一个值,所以这里更具当前的页面状态是编辑还是新增加了判断,分开处理。

调试一下编辑保存,查看入参以及数据库落库都正常。

调试一下新增保存,查看入参以及数据库落库都正常。

五、编辑回显模块节点
此时我点击编辑按钮打开编辑页面,发现是没显示已保存的模块节点的。

F12 查看打开编辑调用的接口,发现接口返回里有了 moduleId 。
但是我原接口里返回的是 int 类型,这里看控制台里组件里的是字符串,所以我尝试修改了下后端的接口,以及数据库的字段类型,正常了。

看下效果。

坑填上了,也想动动手的小伙伴可以通过公众号回复【测试平台】获取系列教程文章以及源码地址。
边栏推荐
- Pagehepler lost the pit of the original SQL order by condition
- The win11 installation system prompts that VirtualBox is incompatible and needs to uninstall the solution of virtual, but the uninstall list cannot find the solution of virtual
- 关于flex布局justify-content:space-around最后一个不对齐的解决方法和为什么这样子解决是讨论
- Dynamic programming -- knapsack problem
- Looking for peak [Abstract dichotomy exercise]
- Chicken and egg, products and Strategies
- 基于EFR32MG24的AI 加速度姿势识别体验
- 338. 比特位计数
- Palindrome related topics
- Consensys Quorum Benchmark Test
猜你喜欢

Which is a good fixed asset management system? What are the fixed asset management platforms?

基本51单片机点阵汉字显示程序设计

R语言实战应用案例:绘图篇(三)-多种组合图型绘制

Wacom firmware update error 123, digital board driver cannot be updated

js日历样式饼图统计插件

The win11 installation system prompts that VirtualBox is incompatible and needs to uninstall the solution of virtual, but the uninstall list cannot find the solution of virtual

優化華為雲服務器采用Key登陸

Yunna - how to strengthen fixed asset management? How to strengthen the management of fixed assets?
建议思源笔记能够兼容第三方同步盘

Dynamic programming -- knapsack problem
随机推荐
Yunna - how to strengthen fixed asset management? How to strengthen the management of fixed assets?
Quanzhi f1c100s/f1c200s learning notes (13) -- lvgl transplantation
Authing supports Zadig! Unified authentication and rapid docking of cloud native users
Summary of different circulation modes and precautions in JS
webstrom ERROR in [eslint] ESLint is not a constructor
Find the maximum area of the island -- depth first search (staining method)
Pycharm读取Excel文件时报错:raise XLRDError(FILE_FORMAT_DESCRIPTIONS[file_format]+ ; not supported )
-bash: ifconfig: command not found
npm warn config global `--global`, `--local` are deprecated. use `--location=global` instead.
10 years of software testing engineer experience, very confused
炫酷代码雨动态背景注册页面
手工测试如何转向自动化测试?字节5年自动化经验浅谈一下...
(heavy chain dissection) Magic Tree
pageHepler丢失原sql order by条件的坑
js软件卸载提示表情跟随鼠标变化js特效
打家劫舍!
微信官方出品!小程序自动化框架 minium 分享预告
Due to resource constraints, the namenode fails to start with an error unable to create new native thread
[C language] number guessing game + shutdown applet
優化華為雲服務器采用Key登陸