index.vue 2.75 KB
<template>
  <el-form ref="form" size="small" :model="formModel">
    {{ formModel }}
    <form-render :list="formList" :model="model" @item-change="onItemChange" @form-item-change="onFormItemChange"></form-render>
  </el-form>
</template>

<script>
import FormRender from './form-render';

export default {
  components: { FormRender },
  props: {
    value: Object,
    list: Array,
  },
  data() {
    return {
      model: {},
      formModel: {}
    }
  },
  watch: {
    value(val) {
      const data = val || {};
      this.model = data;
      let formModel = {};
      const setFormModelValue = (list, parentKey) => {
        list.forEach(item => {
          item.fullKey = `${parentKey ? `${parentKey}-${item.key}` : item.key}`;
          if (item.value instanceof Object) {
            setFormModelValue(Object.keys(item.value).map(key => ({ key, value: item.value[key] })), item.fullKey);
          } else {
            if (item.fullKey) {
              formModel[item.fullKey] = item.value;
            }
          }
        });
      };
      setFormModelValue(Object.keys(data).map(key => ({ key, value: data[key] })));
      // console.log(formModel);
      // Object.keys(formModel).forEach(key => {
      //   this.formModel[key] = formModel[key];
      // });
      if (Object.keys(formModel).length > 0) {
        console.log(formModel);
        this.formModel = formModel;
      }
    },
  },
  computed: {
    formList() {
      const newList = [...new Set(this.list)]
      const generateFullKey = (list, parentKey) => {
        list.forEach(item => {
          if (item.group && item.list) {
            if (item.group.key) {
              item.fullKey = `${parentKey ? `${parentKey}-${item.group.key}` : item.group.key}`;
              // if (item.fullKey) {
              //   this.formModel[item.fullKey] = '';
              // }
            } else {
              item.fullKey = item.key;
              // if (item.fullKey) {
              //   this.formModel[item.fullKey] = '';
              // }
            }
            generateFullKey(item.list, item.fullKey);
          } else {
            item.fullKey = `${parentKey ? `${parentKey}-${item.key}` : item.key}`;
            // if (item.fullKey) {
            //   this.formModel[item.fullKey] = '';
            // }
          }
        });
      };
      generateFullKey(newList);
      return newList;
    }
  },
  methods: {
    // 表单项值变化
    onItemChange(item) {
      this.$emit('input', { ...this.model, ...item });
    },
    // 表单相校验值变化
    onFormItemChange(item) {
      this.formModel = { ...this.formModel, ...item };
    },
    // 校验表单
    validate() {
      this.$refs.form.validate(valid => {
        this.$emit("validate", valid);
      });
    },
  }
}
</script>

<style>

</style>