【测试平台开发】十七、接口编辑页面实现下拉级联选择,绑定接口所属模块

简介: 【测试平台开发】十七、接口编辑页面实现下拉级联选择,绑定接口所属模块

基于 springboot+vue 的测试平台开发继续更新。


停更得有半年,最近待业家中没有理由不继续更新了。本来是打算做别的功能,但是我的重新调试环境的时候发现了bug,搞半天原来是因为没实现接口与模块的绑定,导致点击左侧模块树之后列表页就没数据。气死我了,那先来把这个坑填上。


先看一下最后的功能效果动图。


1268169-20220321105811597-275993014.gif


因为完善这个功能要涉及一些之前功能的改动,所以接下来以实际的开发修改过程来记录内容(源码获取在文末):


  1. 寻找级联组件
  2. 后端返回组件需要的数据内容
  3. 修改前端内容,使用级联组件
  4. 修改新增、编辑功能,保存选择的模块
  5. 修改编辑回显功能,显示对应节点


一、级联选择器组件


elementUI 官网,找到级联选择器组件。


1268169-20220321110532621-1427792834.png


查看组件的功能属性,发现可以满足我的需求:


  • 悬停触发级联菜单
  • 支持单独选择每一级
  • 支持搜索节点


二、后端返回组件需要的数据


查看组件属性得知所需的数据内容,value用于存放选择的节点,注意这里存进去的是数组。而options就是数据源来,也是一个数组,里面的属性有:


  • value,选择节点时候的赋值
  • label,显示的节点文本内容
  • children,子节点嵌套的内容


1268169-20220321111345096-1661062035.png


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


1268169-20220321111659003-1626233814.png


对于这个模块树我后端是有一个专门的接口返回的,所以我打算复用这个接口。思路就是当这个接口被请求的时候,我再把这个接口返回的数据赋值options即可。


但是用下来发现后端原接口是少了一个返回字段value,会导致选择的时候有bug,所以我修改了后端接口,增加一个字段的返回。


1268169-20220321112246357-879486072.png


新增的字段里的值我使用模块id,不会重复。


F12看下修改后的接口返回,没问题。


1268169-20220321112507276-804171572.png


三、前端使用级联组件


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


1268169-20220321112806919-1488920251.png


说一下用到的组件属性:


  • :show-all-levels="false": 输入框中是否显示选中值的完整路径,false就只显示最后一级。
  • filterable: 是否可搜索选项,开启
  • placeholder: 占位符,显示背景内容
  • clearable:支持清空选项
  • v-model: 绑定你选中的节点value 到某个字段上
  • options: 后端接口返回的数据,存放在这个字段上
  • :props:用到的一些其他配置选项
  • @change:当选中节点变化时触发


{ expandTrigger: 'hover', checkStrictly: true },关于用到的2个 props,作用分别是:


  • expandTrigger:次级菜单的展开方式,hover是鼠标悬停展开,我觉得比较方便。
  • checkStrictly: 是否严格的遵守父子节点不互相关联,true 就可以支持任意一个节点的选择。


四、新增、编辑里保存选择的模块


我重新查看了前端点击保存按钮的代码,发现会判断此时是新增还是编辑,从而选择调用对应的新增或者修改方法。


1268169-20220321114346169-789939202.png


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


1268169-20220321114525692-1882847190.png


找到方法了对应的模块id的字段,之前我没实现这个功能的时候,是写死了 0。


这里我前端做了一下处理,因为后端接口接收到参数是int,但是组件这里 value 是数组,通过在handleChange方法里加log打印,查看控制台里的返回便知。


1268169-20220321115043144-371151277.png


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


1268169-20220321115200720-1338223220.png


本来以为这样就可以了,后来调试时候发现bug,最后发现新增和编辑的时候,还不能统一都这么处理。


因为新增的时候传入的是数组,但是编辑的时候就只是一个值,所以这里更具当前的页面状态是编辑还是新增加了判断,分开处理。


1268169-20220321142856528-1566840454.png


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


1268169-20220321115418203-1701897757.png


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


1268169-20220321115509817-601742860.png


五、编辑回显模块节点


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


1268169-20220321115704201-1375973723.png


F12 查看打开编辑调用的接口,发现接口返回里有了 moduleId 。


1268169-20220321115654329-505832472.png


但是我原接口里返回的是 int 类型,这里看控制台里组件里的是字符串,所以我尝试修改了下后端的接口,以及数据库的字段类型,正常了。


1268169-20220321124430276-1152612177.png


看下效果。


1268169-20220321124704128-565916313.gif


坑填上了,也想动动手的小伙伴可以通过公众号回复【测试平台】获取系列教程文章以及源码地址。

相关文章
|
21天前
|
移动开发 JSON Java
Jmeter实现WebSocket协议的接口测试方法
WebSocket协议是HTML5的一种新协议,实现了浏览器与服务器之间的全双工通信。通过简单的握手动作,双方可直接传输数据。其优势包括极小的头部开销和服务器推送功能。使用JMeter进行WebSocket接口和性能测试时,需安装特定插件并配置相关参数,如服务器地址、端口号等,还可通过CSV文件实现参数化,以满足不同测试需求。
98 7
Jmeter实现WebSocket协议的接口测试方法
|
21天前
|
JSON 移动开发 监控
快速上手|HTTP 接口功能自动化测试
HTTP接口功能测试对于确保Web应用和H5应用的数据正确性至关重要。这类测试主要针对后台HTTP接口,通过构造不同参数输入值并获取JSON格式的输出结果来进行验证。HTTP协议基于TCP连接,包括请求与响应模式。请求由请求行、消息报头和请求正文组成,响应则包含状态行、消息报头及响应正文。常用的请求方法有GET、POST等,而响应状态码如2xx代表成功。测试过程使用Python语言和pycurl模块调用接口,并通过断言机制比对实际与预期结果,确保功能正确性。
96 3
快速上手|HTTP 接口功能自动化测试
|
8天前
|
测试技术 持续交付 UED
软件测试的艺术与科学:平衡创新与质量的探索在软件开发的波澜壮阔中,软件测试如同灯塔,指引着产品质量的方向。本文旨在深入探讨软件测试的核心价值,通过分析其在现代软件工程中的应用,揭示其背后的艺术性与科学性,并探讨如何在追求技术创新的同时确保产品的高质量标准。
软件测试不仅仅是技术活动,它融合了创造力和方法论,是软件开发过程中不可或缺的一环。本文首先概述了软件测试的重要性及其在项目生命周期中的角色,随后详细讨论了测试用例设计的创新方法、自动化测试的策略与挑战,以及如何通过持续集成/持续部署(CI/CD)流程优化产品质量。最后,文章强调了团队间沟通在确保测试有效性中的关键作用,并通过案例分析展示了这些原则在实践中的应用。
26 1
|
21天前
|
JavaScript 前端开发 测试技术
ChatGPT与接口测试
ChatGPT与接口测试,测试通过
30 5
|
6天前
|
测试技术 UED 开发者
软件测试的艺术:从代码审查到用户反馈的全景探索在软件开发的宇宙中,测试是那颗确保星系正常运转的暗物质。它或许不总是站在聚光灯下,但无疑是支撑整个系统稳定性与可靠性的基石。《软件测试的艺术:从代码审查到用户反馈的全景探索》一文,旨在揭开软件测试这一神秘面纱,通过深入浅出的方式,引领读者穿梭于测试的各个环节,从细微处着眼,至宏观视角俯瞰,全方位解析如何打造无懈可击的软件产品。
本文以“软件测试的艺术”为核心,创新性地将技术深度与通俗易懂的语言风格相结合,绘制了一幅从代码审查到用户反馈全过程的测试蓝图。不同于常规摘要的枯燥概述,这里更像是一段旅程的预告片,承诺带领读者经历一场从微观世界到宏观视野的探索之旅,揭示每一个测试环节背后的哲学与实践智慧,让即便是非专业人士也能领略到软件测试的魅力所在,并从中获取实用的启示。
|
2月前
|
测试技术 C# 开发者
“代码守护者:详解WPF开发中的单元测试策略与实践——从选择测试框架到编写模拟对象,全方位保障你的应用程序质量”
【8月更文挑战第31天】单元测试是确保软件质量的关键实践,尤其在复杂的WPF应用中更为重要。通过为每个小模块编写独立测试用例,可以验证代码的功能正确性并在早期发现错误。本文将介绍如何在WPF项目中引入单元测试,并通过具体示例演示其实施过程。首先选择合适的测试框架如NUnit或xUnit.net,并利用Moq模拟框架隔离外部依赖。接着,通过一个简单的WPF应用程序示例,展示如何模拟`IUserRepository`接口并验证`MainViewModel`加载用户数据的正确性。这有助于确保代码质量和未来的重构与扩展。
30 0
|
2月前
|
网络协议 测试技术 网络安全
Python进行Socket接口测试的实现
在现代软件开发中,网络通信是不可或缺的一部分。无论是传输数据、获取信息还是实现实时通讯,都离不开可靠的网络连接和有效的数据交换机制。而在网络编程的基础中,Socket(套接字)技术扮演了重要角色。 Socket 允许计算机上的程序通过网络进行通信,它是网络通信的基础。Python 提供了强大且易于使用的 socket 模块,使开发者能够轻松地创建客户端和服务器应用,实现数据传输和交互。 本文将深入探讨如何利用 Python 编程语言来进行 Socket 接口测试。我们将从基础概念开始介绍,逐步引导大家掌握创建、测试和优化 socket 接口的关键技能。希望本文可以给大家的工作带来一些帮助~
|
2月前
|
网络协议 测试技术 网络安全
Python进行Socket接口测试的实现
在现代软件开发中,网络通信是不可或缺的一部分。无论是传输数据、获取信息还是实现实时通讯,都离不开可靠的网络连接和有效的数据交换机制。而在网络编程的基础中,Socket(套接字)技术扮演了重要角色。 Socket 允许计算机上的程序通过网络进行通信,它是网络通信的基础。Python 提供了强大且易于使用的 socket 模块,使开发者能够轻松地创建客户端和服务器应用,实现数据传输和交互。 本文将深入探讨如何利用 Python 编程语言来进行 Socket 接口测试。我们将从基础概念开始介绍,逐步引导大家掌握创建、测试和优化 socket 接口的关键技能。希望本文可以给大家的工作带来一些帮助~
|
2月前
|
SQL Java 测试技术
SpringBoot单元测试快速写法问题之PorkService 接口中的 getPork 方法的作用如何解决
SpringBoot单元测试快速写法问题之PorkService 接口中的 getPork 方法的作用如何解决
|
3月前
|
存储
Postman 接口测试配置 Pre-request Script
Postman 接口测试配置 Pre-request Script
128 5
Postman 接口测试配置 Pre-request Script
下一篇
无影云桌面