element ui实现多层级复杂表单的操作(添加与回显)之回显功能实现

简介: element ui实现多层级复杂表单的操作(添加与回显)之回显功能实现

父组件引入子组件


[element ui实现多层级复杂表单的操作(添加与回显)之表单操作交互操作](element ui实现多层级复杂表单的操作(添加与回显)之表单操作交互操作_穆雄雄的博客-CSDN博客)第一篇文章我就分析过,这是一个多层级的表单,所以避免不好要使用循环来实现,于是我就在后台封装了两个对象,一个是最外面基本信息的数据,另一个就是采集数据的配置信息。


代码实现如下:


  /**
   * 根据设备编号查询配置文件
   * @return
   */
  @GetMapping("/getDataSourceConfigInfo")
  @ApiOperationSupport(order = 6)
  @ApiOperation(value = "根据设备编号查询配置文件", notes = "传入device")
  public R getDataSourceConfigInfo(Long deviceId){
    //获取设备的信息
    Device device = deviceService.getById(deviceId);
    LambdaQueryWrapper<DataSourceConfig> dataSourceConfigLambdaQueryWrapper = new LambdaQueryWrapper<>();
    dataSourceConfigLambdaQueryWrapper.eq(DataSourceConfig::getDeviceId,deviceId);
    //拿到配置信息的集合
    List<DataSourceConfig> dataSourceConfigList = dataSourceConfigService.list(dataSourceConfigLambdaQueryWrapper);
    Map<String,Object> map = new HashMap<>();
    map.put("device",device);
    map.put("dataSourceConfigList",dataSourceConfigList);
    return R.data(map);
  }


设备的信息都放在了device对象中,配置信息都放在了dataSourceConfigList集合中,这样放的目的就是在前台好遍历。


前台用的子父组件实现的,父组件中引用子组件:


  • 引入子组件:
import editDevice from "./editDevice.vue";


 components: {
    addDevice,
    editDevice,
    viewDevice,
  },


  <el-dialog
      title="编 辑"
      :visible.sync="editDeviceDialogVisible"
      :append-to-body="true"
      width="70%"
    >
      <editDevice
        :editDeviceData="editDeviceData"
        @editDeviceResult="editDeviceResult"
        @quxiaoClickResult="quxiaoClickResult"
      ></editDevice>
    </el-dialog>


其中:editDeviceData是传递给子组件的数据,也就是在控制器中封装查出来的。


editDeviceResult是子组件传递给父组件的方法,我这边是子组件点击了确定之后,告诉父组件一下,然后将其dialog窗体关闭。分别对应的方法如下:


  1. editDeviceData数据获取的方法:
 /*查看设备的按钮*/
    viewDevice(row){
      //获取详细信息
      getDataSourceConfigInfo(row.id).then((res) => {
        this.editDeviceData =res.data.data;
        this.viewDeviceDialogVisible  = true;
      });
    },


2.editDeviceResult编辑成功之后的方法:

  //编辑设备完成
    editDeviceResult(val){
      if(val==true){
        //关掉添加的窗体
        this.editDeviceDialogVisible = false;
        //刷新设备的信息
        this.refreshChangeCard();
      }
    },


3.quxiaoClickResult子组件中取消按钮的实现方法:

 //添加和修改的子组件取消按钮点击事件
    quxiaoClickResult(val){
      if(val==true){
        //关掉添加的窗体
        this.addDeviceDialogVisible = false;
        this.editDeviceDialogVisible = false;
        this.viewDeviceDialogVisible = false;
        //刷新设备的信息
        this.refreshChangeCard();
      }
    },


子组件中实现回显


子组件的核心代码就一个方法,即拿到父组件传过来的数据,进行遍历的显示在页面上。

props:{
    editDeviceData: {
      type:Object
    }
  },


mounted中调用展示数据的方法:

//获取设备的信息
    this.getDeviceInfo();


methods中实现展示数据、封装数据的方法:

   //获取设备的信息
    getDeviceInfo(){
      let mapObject = this.editDeviceData;
      this.form = mapObject.device;
      this.dialogImageUrl = this.form.certificateImgUrl;
      this.productImgs.push({
        name: '',
        url: this.dialogImageUrl,
      });
      let deviceSdkPackage = mapObject
        .device
        .deviceSdkPackage
        .substring(mapObject
          .device.
          deviceSdkPackage
          .lastIndexOf(".")+1);
      this.form.deviceSdkPackage = deviceSdkPackage;
      this.attribute.length = mapObject.dataSourceConfigList.length;
      for(var i =0;i< this.attribute.length;i++) {
        let dataSourceConfig = mapObject.dataSourceConfigList[i];
        this.deviceDataCheck[i] = dataSourceConfig.dataCollectionType;
        this.samplingFrequency[i] = dataSourceConfig.samplingFrequency;
        this.schemeOfDataSourceType[i] = dataSourceConfig.schemeOfDataSourceType;
        this.countOfCompound[i] = dataSourceConfig.countOfCompound;
        this.measurePeriodExist[i] = dataSourceConfig.measurePeriodExist+"";
        var countOfCompoundLength =  this.countOfCompound[i];
        var dataSourceType = (dataSourceConfig.dataSourceType).split(",");
        var unitCode = (dataSourceConfig.unitCode).split(",");
        var dataType = (dataSourceConfig.dataType).split(",");
        var metricSpec = (dataSourceConfig.metricSpec).split(",");
        this.formList[i]=[];
        for(var j = 0;j<dataSourceType.length;j++){
          this.formList[i].push({
            dataSourceType: dataSourceType[j],
            unitCode: unitCode[j],
            dataType: dataType[j],
            metricSpec: metricSpec[j],
          });
        }
      }
    },


以上代码,回显即可实现,实际上后台的代码不是很多,前端代码要比较多点儿,但是只要你思路理清了,其实也没有太复杂。

目录
相关文章
|
7月前
|
Web App开发 前端开发 JavaScript
Element UI框架中自定义input组件的placeholder样式。
确保这些样式在你的应用程序CSS文件中定义,且该文件已正确加载到项目中。通过以上方法,可以控制Element UI组件中input的placeholder样式,使其满足特定的设计要求。这些更改都是基于CSS伪元素进行的,因此并不会对DOM结构产生改变,保持了原有结构的简洁和高效。
635 12
|
7月前
|
存储 JavaScript 前端开发
element ui <el-date-picker> 设置展示当前月
在 Element UI 中,使用 `el-date-picker` 的 `value-format` 属性可将日期值格式化为指定字符串。设置 `type=&quot;month&quot;` 时,绑定值默认为 Date 对象,通过 `value-format=&quot;yyyy-MM&quot;` 可将其转为如 &quot;2023-05&quot; 格式,便于存储与处理。
1329 0
|
8月前
|
定位技术 容器
48.[HarmonyOS NEXT RelativeContainer案例五] 精确表单布局:辅助线定位技术打造专业级UI
在HarmonyOS NEXT的UI开发中,表单是常见且重要的界面元素。创建对齐精确、布局合理的表单需要精细的定位控制。RelativeContainer提供的辅助线(Guideline)功能,为表单布局提供了强大的支持。本教程将详细讲解如何使用RelativeContainer的辅助线功能实现精确的表单布局,帮助你掌握这一专业级UI技术。
220 7
|
API UED 容器
深入探索 Element UI:自定义滚动条与弹出层管理的技巧
在这篇博客中,我们将深入探讨 Element UI 中的自定义滚动条及弹出层管理技巧。文章详细介绍了 el-scrollbar 组件的使用和参数设置,以及 PopupManager 如何有效管理弹出层的 z-index。我们还将探讨如何实现灵活的全屏组件,利用 vue-popper 创建自定义弹出层,最后介绍 ClickOutside 指令的用法。这些高级技巧将帮助你提升 Element UI 应用程序的用户体验与交互灵活性。
1518 1
深入探索 Element UI:自定义滚动条与弹出层管理的技巧
|
JavaScript 索引
Vue开发中Element UI/Plus使用指南:常见问题(如Missing required prop: “value“)及中文全局组件配置解决方案
Vue开发中Element UI/Plus使用指南:常见问题(如Missing required prop: “value“)及中文全局组件配置解决方案
1164 0
|
9月前
|
开发框架 前端开发 JavaScript
【HarmonyOS Next之旅】基于ArkTS开发(二) -> UI开发一
本文介绍了方舟开发框架(ArkUI)及其两种开发范式:基于ArkTS的声明式开发范式和类Web开发范式。ArkUI是用于构建HarmonyOS应用界面的UI框架,提供极简UI语法和基础设施。声明式开发范式使用ArkTS语言,以组件、动画和状态管理为核心,适合复杂团队协作;类Web开发范式采用HML、CSS、JavaScript三段式开发,适用于简单界面应用,贴近Web开发者习惯。文中还概述了两者的架构和基础能力,帮助开发者选择合适的范式进行高效开发。
303 15
|
9月前
|
编解码 前端开发 Java
【HarmonyOS Next之旅】基于ArkTS开发(二) -> UI开发三
本文介绍了基于声明式UI范式的图形绘制与动画效果实现方法,涵盖绘制图形、添加动画效果及常见组件说明三部分内容。在绘制图形部分,详细讲解了如何通过Circle组件为食物成分表添加圆形标签,以及使用Path组件结合SVG命令绘制自定义图形(如应用Logo)。动画效果部分则展示了如何利用animateTo实现闪屏动画,包括渐出、放大效果,并设置页面跳转;同时介绍了页面间共享元素转场动画的实现方式。最后,文章列举了声明式开发范式中的各类组件及其功能,帮助开发者快速上手构建复杂交互页面。
343 11
|
5月前
|
存储 开发者 容器
鸿蒙 HarmonyOS NEXT星河版APP应用开发-ArkTS面向对象及组件化UI开发使用实例
本文介绍了ArkTS语言中的Class类、泛型、接口、模块化、自定义组件及状态管理等核心概念,并结合代码示例讲解了对象属性、构造方法、继承、静态成员、访问修饰符等内容,同时涵盖了路由管理、生命周期和Stage模型等应用开发关键知识点。
451 1
鸿蒙 HarmonyOS NEXT星河版APP应用开发-ArkTS面向对象及组件化UI开发使用实例
|
8月前
|
JavaScript 前端开发 UED
【HarmonyOS Next之旅】基于ArkTS开发(二) -> UI开发四
本文介绍了Web组件开发与性能优化的相关内容。在Web组件开发部分,涵盖创建组件、设置样式与属性、添加事件和方法以及场景示例,如动态播放视频。性能提升方面,推荐使用数据懒加载、条件渲染替代显隐控制、Column/Row替代Flex、设置List组件宽高及调整cachedCount减少滑动白块等方法,以优化应用性能与用户体验。
296 56
|
8月前
|
编解码 UED 开发者
【HarmonyOS Next之旅】基于ArkTS开发(二) -> UI开发之常见布局
本文主要介绍了自适应布局与响应式布局的相关内容。自适应布局部分涵盖线性布局、层叠布局、弹性布局和网格布局,详细说明了各布局的特性及使用方法,例如线性布局中的排列、拉伸与缩放,弹性布局的方向、换行与对齐方式等。响应式布局则重点讲解了栅格系统和媒体查询,阐述如何通过栅格组件和媒体查询条件实现不同设备上的适配效果。这些技术帮助开发者灵活应对多尺寸屏幕的设计需求,提升用户体验。
437 55

热门文章

最新文章