a00r 2022-02-16 16:32 采纳率: 100%
浏览 70
已结题

vue异步更新与$nextTick

用的element表单生成器

//生成器插件部分源码
submitForm() {
      this.$refs[this.formConf.formRef].validate(valid => {
        if (!valid) return false
        // 触发sumit事件
        this.$emit('submit', this[this.formConf.formModel])
        return true
      })
    }

<template>
  <div>
    <parser
      v-if="isDataReady"
      :form-conf="formConf"
      ref="parser"
      @submit="currFormSubmit"
    />
  </div>
</template>

<script>
import Parser from "form-gen-parser";
import {
  designDetail,
  formSave,
} from "../../../../api/formGenerator/api_formGenerator";
import { buildingOnLandSave } from "@/api/landBuild/yd.js"

export default {
  components: {
    Parser,
  },
  data() {
    return {
      formConf: null,
      refName: "parser",
      testData: null,
      isDataReady: false,
      formPerData: null,
      formModel: null, //当前表单标识
      formRef: null, //当前表单名称
      valid: false,//当前表单是否通过验证
    };
  },
  mounted() {
    this.designDetail()
  },
  methods: {
    designDetail() {
      designDetail({ formId: "6afef2143e229a999920d89a365c3402" }).then((res) => {
        if (res.code == 0) {
          this.formConf = JSON.parse(res.data.formDesign.setup);
          this.isDataReady = true;
          this.formPerData = res.data.formDesign;

          this.$nextTick(() => {
            this.$emit('getCode', this.findAreaCode());
          })
        }
      })
    },
    submitForm() {
      //表单验证
      this.$refs.parser.submitForm();
      console.log(this.valid)
      this.$nextTick(() => {
        console.log(this.valid)
        if (!this.valid) {
          this.$message.error('表单信息未填写或格式错误,请重新填写!')
            return [];
        }
        let formdata = this.$refs.parser[this.formModel];
        /**测试数据 */
        formdata.xzqdm = '36072310620701';
        return [formdata, this.$refs.parser.formConfCopy];
      })
    },
    //parser submit
    currFormSubmit() {
      this.valid = true;
    },
  },
};
</script>

假设表单验证通过
问: 第二页submitForm方法中的console打印结果?为什么?

  • 写回答

2条回答 默认 最新

  • _念_ 2022-02-16 16:47
    关注

    为啥要这么做,element的表单验证方法是一个promise,你完全可以在子组件的提交的方法里面直接return 整个验证方法,外层能够接到一个promise对象的,
    就算不用这种你也可以在调用子组件的对象的时候,传入一个函数,子对象内部校验通过后调用回调。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 2月26日
  • 已采纳回答 2月18日
  • 创建了问题 2月16日

悬赏问题

  • ¥120 计算机网络的新校区组网设计
  • ¥20 完全没有学习过GAN,看了CSDN的一篇文章,里面有代码但是完全不知道如何操作
  • ¥15 使用ue5插件narrative时如何切换关卡也保存叙事任务记录
  • ¥20 海浪数据 南海地区海况数据,波浪数据
  • ¥20 软件测试决策法疑问求解答
  • ¥15 win11 23H2删除推荐的项目,支持注册表等
  • ¥15 matlab 用yalmip搭建模型,cplex求解,线性化处理的方法
  • ¥15 qt6.6.3 基于百度云的语音识别 不会改
  • ¥15 关于#目标检测#的问题:大概就是类似后台自动检测某下架商品的库存,在他监测到该商品上架并且可以购买的瞬间点击立即购买下单
  • ¥15 神经网络怎么把隐含层变量融合到损失函数中?