vue框架编辑接口页面下拉级联选择并绑定接口所属模块

 更新时间:2022年05月26日 14:19:53   作者:把苹果咬哭的测试笔记  
这篇文章主要为大家介绍了vue框架编辑接口页面实现下拉级联选择以及绑定接口所属模块,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

基于 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 类型,这里看控制台里组件里的是字符串,所以我尝试修改了下后端的接口,以及数据库的字段类型,正常了。

看下效果。

坑填上了,完整代码更新

前端:

https://github.com/wessonlan/bloomtest-web

后端

https://github.com/wessonlan/bloomtest-backend

以上就是vue框架编辑接口页面下拉级联选择并绑定接口所属模块的详细内容,更多关于vue下拉级联选择并绑定接口所属模块的资料请关注脚本之家其它相关文章!

相关文章

  • Vue中的scoped和 elememt-plus的样式修改方法

    Vue中的scoped和 elememt-plus的样式修改方法

    Vue中的scoped属性用于实现样式隔离,确保组件间的样式互不影响,通过在组件的style标签内添加任何内容,可以为组件生成一个唯一的哈希值,从而实现样式的定位,本文通过实例代码讲解Vue中的scoped和 elememt-plus的样式修改方法,感兴趣的朋友一起看看吧
    2025-01-01
  • Vue路由守卫详解

    Vue路由守卫详解

    路由导航守卫提供了一些钩子函数,可以在路由导航过程中进行拦截和控制,其中,beforeEach 导航守卫可以在每次路由切换前被触发,本文给大家介绍Vue路由守卫详解,感兴趣的朋友一起看看吧
    2023-10-10
  • vue 打包后找不到dist文件夹的解决方案

    vue 打包后找不到dist文件夹的解决方案

    这篇文章主要介绍了vue 打包后找不到dist文件夹的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-05-05
  • 使用vue.js编写蓝色拼图小游戏

    使用vue.js编写蓝色拼图小游戏

    之前在网上看到《蓝色拼图》这款小游戏,作者是用jquery写的。下面通过本文给大家分享基于vue.js编写蓝色拼图小游戏,一起看看实现代码吧
    2017-03-03
  • vue移动端下拉刷新和上滑加载

    vue移动端下拉刷新和上滑加载

    这篇文章主要为大家详细介绍了vue移动端下拉刷新和上滑加载,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-10-10
  • vue路由懒加载工作原理

    vue路由懒加载工作原理

    Vue路由懒加载是一种优化技术,旨在减少应用程序的初始加载时间并提高性能,这篇文章给大家介绍vue路由懒加载的相关知识,感兴趣的朋友跟随小编一起看看吧
    2024-05-05
  • vue自定义穿梭框支持远程滚动加载的实现方法

    vue自定义穿梭框支持远程滚动加载的实现方法

    这篇文章主要介绍了vue自定义穿梭框支持远程滚动加载,iview是全局注入,基本使用原先的类名进行二次创建公共组件,修改基础js实现逻辑,本文结合实例代码介绍的非常详细,需要的朋友可以参考下
    2023-08-08
  • Vue 解决父组件跳转子路由后当前导航active样式消失问题

    Vue 解决父组件跳转子路由后当前导航active样式消失问题

    这篇文章主要介绍了Vue 解决父组件跳转子路由后当前导航active样式消失问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-07-07
  • vue子组件实时获取父组件的数据实现

    vue子组件实时获取父组件的数据实现

    本文主要介绍了vue子组件实时获取父组件的数据实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-12-12
  • vite5+vue3+ import.meta.glob动态导入vue组件图文教程

    vite5+vue3+ import.meta.glob动态导入vue组件图文教程

    import.meta.glob是Vite提供的一个特殊功能,它允许你在模块范围内动态地导入多个模块,这篇文章主要给大家介绍了关于vite5+vue3+ import.meta.glob动态导入vue组件的相关资料,需要的朋友可以参考下
    2024-07-07

最新评论