基于jeecgboot的大屏设计器开发——数据源设计(三)
创始人
2025-05-30 17:04:58

     之前主要是讲了数据源的录入与数据库测试功能,但保存这块没有说,今天主要讲保存这块。

     因为通过online设计表单生成的代码已经有保存功能,所以主要功能不需要修改,只需要修改下面几个方面就可以。

    一、保存按钮的修改

     主要是增加了两个:

    1、新的值包括用户可能编辑的数据重新赋值给model

        const newList = {};
        this.dataLink.forEach(item => {
          newList[item.label] = item.value;
        });
        this.model.config = JSON.stringify(newList);

    2、保存的时候进行检查,需要测试OK后才能保存

        if (this.testReplyCode != "200") {
              this.$message.error("测试结果为成功后方可保存!");
              return;
            }

     3、具体完整代码如下:

submitForm () {const that = this;const newList = {};this.dataLink.forEach(item => {newList[item.label] = item.value;});this.model.config = JSON.stringify(newList);// 触发表单验证this.$refs.form.validate(valid => {if (valid) {if (this.testReplyCode != "200") {this.$message.error("测试结果为成功后方可保存!");return;}that.confirmLoading = true;let httpurl = '';let method = '';if(!this.model.id){httpurl+=this.url.add;method = 'post';}else{httpurl+=this.url.edit;method = 'put';}httpAction(httpurl,this.model,method).then((res)=>{if(res.success){that.$message.success(res.message);that.$emit('ok');}else{that.$message.warning(res.message);}}).finally(() => {that.confirmLoading = false;})}})},

  二、编辑的时候处理

1、在edit增加一个初始化

     if (record.id) {根据record.id判断新增还是编辑
          this.editInit(this.model.type);
        }  

    这里需要区分一下是新增还是编辑,两个不一样。

2、初始化读出的数据

    要结合读出的数据与原来type类型的进行更新处理,再显示出来,完整代码如下:

 edit (record) {this.model = Object.assign({}, record);if (record.id) {根据record.id判断新增还是编辑this.editInit(this.model.type);}  this.visible = true;},
editInit(type) {const that = this;let url = this.url.queryByCode, method = 'get';let params = {code: type};getAction(url,params).then((res)=>{if(res.success){//that.$message.success(res.message);console.log("onchange res=",res);that.dataLink = JSON.parse(res.result.jsonValue);console.log("onchange that.dataLink=",that.dataLink);let newDataLink = [];newDataLink = that.dataLink;let sourceConfigJson = JSON.parse(that.model.config);for (let i = 0; i < newDataLink.length; i++) {newDataLink[i].value = sourceConfigJson[newDataLink[i].label];}this.dataLink = newDataLink;}else{that.$message.warning(res.message);}}).finally(() => {that.confirmLoading = false;})},

三、效果图

相关内容

热门资讯

昊海生科拟受让瑞济生物19.8... 北京商报讯(记者 丁宁)12月12日晚间,昊海生科(688366)发布公告称,公司拟以自有资金383...
原创 飞... 散瓶批发参考价跌至1485元/瓶,原箱产品报价1495元,较年初价格累计跌幅超30%,曾经一瓶难求的...
王源北京跨晚活动展现独特氛围 近日,王源在北京举办的跨晚活动引发了广泛关注,现场氛围热烈,吸引了众多粉丝的参与。活动于2025年举...
2025年度《财经》长青企业案... “2026《财经》可持续发展论坛暨长青企业案例发布仪式”即将启幕,敬请期待。 2025年,是“十四五...
迎接飞机“退役潮” 资环绿投与... 天津北方网讯:日前,中国资环旗下资环绿投国际公司与中飞航空后市场控股有限公司(简称“中飞后市场”)正...