目录
基于springboot+vue的测试平台开发
一、前端Tree树形控件的append方法
二、后端实现节点新增接口
1. controller 层
2. service 层
三、前后端联调
四、编辑节点名称
1. 打开对话框
2. 新增节点
3. 测试
首页 Java java教程 springboot vue前后端接口测试树结点添加功能的方法

springboot vue前后端接口测试树结点添加功能的方法

May 10, 2023 pm 05:10 PM
vue springboot

基于springboot+vue的测试平台开发

一、前端Tree树形控件的append方法

在elementUI 树控件下有个append方法,可以用来为 Tree 中的一个节点追加一个子节点。

springboot vue前后端接口测试树结点添加功能的方法

目前我们已经完成了树列表的接口,可以在 append 方法中输出一下传入的 data 里到底是什么。

console.log('传入的node:' + JSON.stringify(data))
登录后复制

springboot vue前后端接口测试树结点添加功能的方法

点击顶层的默认节点,F12 查看控制台,

springboot vue前后端接口测试树结点添加功能的方法

可以看到:

springboot vue前后端接口测试树结点添加功能的方法

格式化看下其实就是整个节点的树形结构。点击哪一个节点,data 内容就是这个节点下的所有节点数据。

但实际上,我只需要当前点击的节点的数据即可,这个节点下的 children 可以不关心,不过考虑到数据量也不大,就整个传给后端好了。

二、后端实现节点新增接口

我要实现的功能是点击哪个节点的添加按钮,就是添加这个节点的子节点,比如:

springboot vue前后端接口测试树结点添加功能的方法

既然前端可以拿到当前节点的数据,那么新增接口的思路也就有了:

拿到前端传过来的当前节点的数据set 创建时间、更新时间set 好 pos,也就是这个新增的子结点在兄弟节点中的位置顺序set 子结点的层级,也就是当前节点的 level + 1set 子节点的父节点,也就是当前传入接口的节点的 idset 新增节点的名称,=最后进行 insert

1. controller 层

新增对应的控制器方法:

@PostMapping("/add")
  public Result addNode(@RequestBody ApiModule node) {
      try {
          System.out.println(node);
          Long nodeId = apiModuleService.addNode(node);
          return Result.success(nodeId);
      } catch (Exception e) {
          return Result.fail(e.toString());
      }
  }
登录后复制
2. service 层

实现 addNode 方法:

public Long addNode(ApiModule node) {
        node.setCreateTime(new Date());
        node.setUpdateTime(new Date());
        double pos = getNextLevelPos(node.getProjectId(), node.getLevel(), node.getId());
        node.setPos(pos);
        node.setLevel(node.getLevel() + 1);
        node.setParentId(node.getId());
        node.setName("ceshi111");
        apiModuleDAO.insert(node);
        return node.getId();
    }
登录后复制

这里就是按照上述思路来进行实现,setName 暂时用一个固定值代替,先看下新增接口是否可以正常实现。

这里 pos 处理稍微麻烦一点,这个是代表新增的这个节点处于的位置顺序,所以抽出去新增了一个方法实现getNextLevelPos

private double getNextLevelPos(Long projectId, int level, Long nodeId) {
      // 查询项目下,同parentId下,所有节点
      QueryWrapper<ApiModule> queryWrapper = new QueryWrapper<>();
      queryWrapper.eq("projectId", projectId)
                  .eq("level", level + 1)
                  .eq("parentId", nodeId)
                  .orderByDesc("pos");
      List<ApiModule> apiModules = apiModuleDAO.selectList(queryWrapper);
      if (!CollectionUtil.isEmpty(apiModules)) {
          // 不为空,获取最新的同级结点 pos 再加 1,作为下一个
          return apiModules.get(0).getPos() + 1;
      } else {
          // 否则就是当前父节点里的第一个子结点,pos 直接为 1
          return 1;
      }
  }
登录后复制

查询项目下,同parentId,所有节点数据,注意这里的查询条件。

.eq("level", level + 1),当前层级 + 1 作为子节点的层级.eq("parentId", nodeId),当前节点作为父节点

然后判断查询出来的结果,如果列表不为空,返回最新的一个子结点的 pos 加上 1,作为下一个子结点的位置。

否则,新增的节点就是当前父节点里的第一个子节点,直接返回 1 ,作为 pos 值。

三、前后端联调

前端写好接口,然后页面里调用接口。

springboot vue前后端接口测试树结点添加功能的方法

调用接口,增加成功提示,然后刷新树列表。

springboot vue前后端接口测试树结点添加功能的方法

功能正常,在对应节点下新增了固定名称“ceshi111”的子结点,并且刷新树,展示出最新数据。

springboot vue前后端接口测试树结点添加功能的方法

四、编辑节点名称

上面完成了,证明功能没啥大问题了,现在只需要解决节点名称编辑的问题。决定还是用对话框 dialog 来解决。

点击添加按钮,打开对话框,可以输入节点名称,然后保存。该对话框同样适用于编辑场景。

在项目管理功能中,已经用过一次对话框,我直接copy过来相关代码,进行修改。

springboot vue前后端接口测试树结点添加功能的方法

对应 return 里:

springboot vue前后端接口测试树结点添加功能的方法

对话框里会有 2 个按钮:取消和保存。当点击保存的按钮的时候,会根据当前是新建还是修改来调用不同的方法。

1. 打开对话框

修改 append 方法,点击新增按钮时候需要打开对话框。

还有一个重要点,因为新增结点需要传入 data,而现在实际进行新增操作的是handleNodeAdd方法。所以需要在打开对话框的时候,把 data 存下来。

于是,在 return 里新建一个字段currentNode: {}:

springboot vue前后端接口测试树结点添加功能的方法

在 append 方法里把 data 赋值给 currentNode:

springboot vue前后端接口测试树结点添加功能的方法

这里this.dialogStatus = 'create'就是显示对话框。

2. 新增节点

在对话框里输入节点名称,点击保存,就好调用handleNodeAdd方法来请求后端接口。

springboot vue前后端接口测试树结点添加功能的方法

因为传给后端的节点名称是我们输入的,所以这里this.currentNode.name = this.form.nodeName即可。

springboot vue前后端接口测试树结点添加功能的方法

请求成功后给个提示,然后清空表单,以免打开对话框后显示上一次的内容。

3. 测试

测试一下功能是否正常,我把项目id=3 下的节点删掉。

springboot vue前后端接口测试树结点添加功能的方法

新增一个测试节点:

springboot vue前后端接口测试树结点添加功能的方法

功能正常。

以上是springboot vue前后端接口测试树结点添加功能的方法的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

vue怎么给按钮添加函数 vue怎么给按钮添加函数 Apr 08, 2025 am 08:51 AM

可以通过以下步骤为 Vue 按钮添加函数:将 HTML 模板中的按钮绑定到一个方法。在 Vue 实例中定义该方法并编写函数逻辑。

vue中怎么用bootstrap vue中怎么用bootstrap Apr 07, 2025 pm 11:33 PM

在 Vue.js 中使用 Bootstrap 分为五个步骤:安装 Bootstrap。在 main.js 中导入 Bootstrap。直接在模板中使用 Bootstrap 组件。可选:自定义样式。可选:使用插件。

vue中的watch怎么用 vue中的watch怎么用 Apr 07, 2025 pm 11:36 PM

Vue.js 中的 watch 选项允许开发者监听特定数据的变化。当数据发生变化时,watch 会触发一个回调函数,用于执行更新视图或其他任务。其配置选项包括 immediate,用于指定是否立即执行回调,以及 deep,用于指定是否递归监听对象或数组的更改。

vue.js怎么引用js文件 vue.js怎么引用js文件 Apr 07, 2025 pm 11:27 PM

在 Vue.js 中引用 JS 文件的方法有三种:直接使用 &lt;script&gt; 标签指定路径;利用 mounted() 生命周期钩子动态导入;通过 Vuex 状态管理库进行导入。

vue多页面开发是啥意思 vue多页面开发是啥意思 Apr 07, 2025 pm 11:57 PM

Vue 多页面开发是一种使用 Vue.js 框架构建应用程序的方法,其中应用程序被划分为独立的页面:代码维护性:将应用程序拆分为多个页面可以使代码更易于管理和维护。模块化:每个页面都可以作为独立的模块,便于重用和替换。路由简单:页面之间的导航可以通过简单的路由配置来管理。SEO 优化:每个页面都有自己的 URL,这有助于搜索引擎优化。

vue返回上一页的方法 vue返回上一页的方法 Apr 07, 2025 pm 11:30 PM

Vue.js 返回上一页有四种方法:$router.go(-1)$router.back()使用 &lt;router-link to=&quot;/&quot;&gt; 组件window.history.back(),方法选择取决于场景。

怎样查询vue的版本 怎样查询vue的版本 Apr 07, 2025 pm 11:24 PM

可以通过以下方法查询 Vue 版本:使用 Vue Devtools 在浏览器的控制台中查看“Vue”选项卡。使用 npm 运行“npm list -g vue”命令。在 package.json 文件的“dependencies”对象中查找 Vue 项。对于 Vue CLI 项目,运行“vue --version”命令。检查 HTML 文件中引用 Vue 文件的 &lt;script&gt; 标签中的版本信息。

vue函数怎么传参数 vue函数怎么传参数 Apr 08, 2025 am 07:36 AM

向 Vue.js 函数传递参数有两种主要方法:使用插槽传递数据或使用 bind 绑定函数,并提供参数:使用插槽传递参数:在组件模板中传递数据,在组件内访问并用作函数的参数。使用 bind 绑定传递参数:在 Vue.js 实例中绑定函数,并提供函数参数。

See all articles