>웹 프론트엔드 >View.js >Vue+ElementUI가 대형 양식을 처리하는 방법

Vue+ElementUI가 대형 양식을 처리하는 방법

青灯夜游
青灯夜游앞으로
2021-11-22 19:49:492386검색

이 기사는 Vue + ElementUI를 사용하여 매우 큰 양식을 처리하는 방법을 보여줍니다. 도움이 되기를 바랍니다!

Vue+ElementUI가 대형 양식을 처리하는 방법

최근 회사의 업무조정으로 인해 이전 장문의 로직이 많이 바뀌어서 재구성할 예정입니다. (퇴사한 배경관리자가 쓴 글이고 댓글이 없습니다. 한 구성 요소는 4000 + OK를 기록했습니다. 저는 정말 무력합니다.) 귀하의 편의를 위해 프로젝트를 14개 구성 요소로 분할하고 단순화했습니다. 14个组件进行了精简。

整体思路

  • 大表单根据业务模块进行拆分
  • 保存时使用el-form提供的validate方法进行校验(循环对每一个拆分的组件进行校验)
  • mixin 对每个组件的公共提取(也利于后期项目的维护)

【相关推荐:《vue.js教程》】

开始

  • 这里以拆分2个组件为例:form1, form2(方便读者观看,命名勿喷)
  • 这里两个组件为什么ref、model绑定的都是form后边会进行说明(为了方便后期维护)
// form1 组件
<template>
    <el-form
      ref="form"
      :model="form"
      label-width="10px"
    >
      <el-form-item label="姓名" prop="name">
          <el-input v-model="form.name" />
      </el-form-item>
    </el-form>
</template>
<script>
export default {
  name: &#39;Form1&#39;,
    props: {
      form: {}
  },
  data() {
    return {
      rules: {
        name: [
          { required: true, message: &#39;请输入姓名&#39;, trigger: &#39;blur&#39; }
        ]
      }
    }
  },
  methods: {
    // 这里是是为了父组件循环调用校验
    validForm() {
        let result = false
        this.$refs.form.validate(valid => valid && (result = true))
        return result
    }
    // 我这里还用了另一种方式写的,但是循环校验的时候是promise对象,有问题,望大佬们指点一二
    validForm() {
        // 明明这里输出的结构是 Boolean 值,但在父组件循环调用之后就是promise类型,需要转换一下才行
        return this.$refs.form.validate().catch(e => console.log(e))
    }
  }
}
</script>

// form2 组件
<template>
    <el-form
      ref="form"
      :model="form"
      label-width="10px"
    >
      <el-form-item label="年龄" prop="age">
          <el-input v-model="form.age" />
      </el-form-item>
    </el-form>
</template>
<script>
export default {
  name: &#39;Form2&#39;,
  props: {
      form: {}
  },
  data() {
    return {
      rules: {
        name: [
          { required: true, message: &#39;请输入年龄&#39;, trigger: &#39;blur&#39; }
        ]
      }
    }
  },
  methods: {
    // 这里是是为了父组件循环调用校验
    validForm() {
        let result = false
        this.$refs.form.validate(valid => valid && (result = true))
        return result
    }
  }
}
</script>
  • 看一下父组件怎么引用的
// 父组件
<template>
    <div class="parent">
        <form1 ref="form1" :form="formData.form1" />
        <form2 ref="form2" :form="formData.form2" />
        <el-button type="primary" @click="save">报错</el-button>
    </div>
</template>
<script>
... 省略引用
export default {
    name: &#39;parent&#39;,
    ... 省略注册
    data () {
        return {
            formData: {
                form1: {},
                form2: {}
            }
        }
    },
}
</script>
  • 由于formData里的属性名form1form2分别用在子表单组件的ref上,因此可以在遍历时依次找到他们,修改保存函数,代码如下:
methods: {
    save () {
        // 每个表单对象的 key 值,也就是每个表单的 ref 值
        const formKeys = Object.keys(this.formData)
        // 执行每个表单的校验方法
        const valids = formKeys.map(item => this.$refs[item].validForm())
        // 所有表单通过检验之后的逻辑
        if (valids.every(item => item)) {
          console.log(11)
        }
    }
}

解答为什么两个组件ref、model绑定的都是form

  • 通过对比我们可以发现form1 form2有共同的 props methods
  • 我们通过 mixin 提取一下
export default {
  props: {
    form: {
      required: true,
      type: Object,
      default: () => {}
    },
  },
  methods: {
    validForm () {
      let result = false
      this.$refs.form.validate(valid => valid && (result = true))
      return result
    }
  }
}
  • form1 form2 中引用该minix

    전체 아이디어

대형 양식은 비즈니스 모듈에 따라 분할됩니다.

    저장 시 el-form에서 제공하는 유효성 검사를 사용하세요 >검증 방법(각 분할 구성 요소의 루프 검증)
  • mixin 각 구성 요소의 공개 추출(향후 프로젝트 유지 관리에도 도움이 됨)
  • [관련 권장 사항: 《vue.js tutorial
  • 》】

여기에서 시작

2개 구성 요소 분할 예: <code>form1, form2 (독자의 편의를 위해 이름을 사용하지 마십시오.)

🎜여기에 두 구성 요소가 있는 이유ref 및 모델은 나중에 설명할 form에 바인딩됩니다(나중에 유지 관리의 편의를 위해)🎜🎜rrreee🎜🎜상위 구성 요소가 어떻게 참조되는지 살펴보세요🎜🎜rrreee🎜🎜왜냐하면 formData의 속성 이름 form1form2는 각각 하위 양식 구성 요소의 ref에 사용되므로 이를 차례로 찾아 저장 기능을 수정합니다. 코드는 다음과 같습니다. 🎜🎜rrreee

두 구성 요소 ref 및 model가 바인딩된 이유를 답하세요. form🎜🎜🎜비교해보면 form1 form2가 동일한 props 메소드를 가지고 있음을 알 수 있습니다🎜🎜mixin을 통해 추출합니다🎜🎜rrreee🎜 🎜에서 form1 form2에서 minix를 참조하고, 해당 컴포넌트에서 해당 속성과 메소드를 삭제하세요🎜🎜🎜End🎜🎜🎜매우 큰 폼을 해결하는 것은 매우 번거롭습니다. , 여기는 그냥 컴포넌트를 위한 것입니다. Splitting🎜🎜컴포넌트 간의 연결도 큰 어려움입니다. 다음번에 완성해서 포스팅하겠습니다🎜🎜댓글란에서 어떻게 해결했는지 토론해 주시는 것도 환영합니다. 저자에게 단점을 지적하기 위해🎜🎜🎜더 많은 프로그래밍 관련 지식을 보려면 🎜프로그래밍 입문🎜을 방문하세요! ! 🎜

위 내용은 Vue+ElementUI가 대형 양식을 처리하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 juejin.cn에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제