이 기사는 Vue + ElementUI를 사용하여 매우 큰 양식을 처리하는 방법을 보여줍니다. 도움이 되기를 바랍니다!
최근 회사의 업무조정으로 인해 이전 장문의 로직이 많이 바뀌어서 재구성할 예정입니다. (퇴사한 배경관리자가 쓴 글이고 댓글이 없습니다. 한 구성 요소는 4000 + OK를 기록했습니다. 저는 정말 무력합니다.) 귀하의 편의를 위해 프로젝트를 14개 구성 요소
로 분할하고 단순화했습니다. 14个组件
进行了精简。
el-form
提供的validate
方法进行校验(循环对每一个拆分的组件进行校验)【相关推荐:《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: 'Form1', props: { form: {} }, data() { return { rules: { name: [ { required: true, message: '请输入姓名', trigger: 'blur' } ] } } }, 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: 'Form2', props: { form: {} }, data() { return { rules: { name: [ { required: true, message: '请输入年龄', trigger: 'blur' } ] } } }, 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: 'parent', ... 省略注册 data () { return { formData: { form1: {}, form2: {} } } }, } </script>
formData
里的属性名form1
和form2
分别用在子表单组件的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
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
에서 제공하는 유효성 검사
를 사용하세요 >검증 방법(각 분할 구성 요소의 루프 검증) 2개 구성 요소 분할 예: <code>form1
, form2
(독자의 편의를 위해 이름을 사용하지 마십시오.)
form
에 바인딩됩니다(나중에 유지 관리의 편의를 위해)🎜🎜rrreee🎜🎜상위 구성 요소가 어떻게 참조되는지 살펴보세요🎜🎜rrreee🎜🎜왜냐하면 formData
의 속성 이름 form1
및 form2
는 각각 하위 양식 구성 요소의 ref
에 사용되므로 이를 차례로 찾아 저장 기능을 수정합니다. 코드는 다음과 같습니다. 🎜🎜rrreeeref 및 model
가 바인딩된 이유를 답하세요. form
🎜🎜🎜비교해보면 form1 form2
가 동일한 props 메소드
를 가지고 있음을 알 수 있습니다🎜🎜mixin을 통해 추출합니다🎜🎜rrreee🎜 🎜에서 form1 form2
에서 minix
를 참조하고, 해당 컴포넌트에서 해당 속성과 메소드를 삭제하세요🎜🎜🎜End🎜🎜🎜매우 큰 폼을 해결하는 것은 매우 번거롭습니다. , 여기는 그냥 컴포넌트를 위한 것입니다. Splitting🎜🎜컴포넌트 간의 연결도 큰 어려움입니다. 다음번에 완성해서 포스팅하겠습니다🎜🎜댓글란에서 어떻게 해결했는지 토론해 주시는 것도 환영합니다. 저자에게 단점을 지적하기 위해🎜🎜🎜더 많은 프로그래밍 관련 지식을 보려면 🎜프로그래밍 입문🎜을 방문하세요! ! 🎜위 내용은 Vue+ElementUI가 대형 양식을 처리하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!