• vue3父组件提交校验多个子组件


    实现功能:在父组件提交事件中校验多个子组件中的form

    父组件:

    1. <script setup lang="ts">
    2. import {ref, reactive} from 'vue'
    3. import childForm from './childForm.vue'
    4. import childForm2 from './childForm2.vue'
    5. let approvalRef = ref()
    6. let approvalRef2 = ref()
    7. let resultArr= reactive([])//存放子组件的数组
    8. let errListMsg =ref("")//用来存储错误提示
    9. //这个方法是固定的,用来创建 Promise 实例,为多个组件校验使用
    10. const checkForm = (formChild) =>{
    11. let result = new Promise((resolve,reject)=>{
    12. formChild.validate((valid,fields)=>{
    13. if (valid) {
    14. console.log('submit');
    15. resolve()
    16. }else{
    17. console.log('error');
    18. Object.keys(fields).forEach((v,index)=>{
    19. if (index==0) {
    20. const PropName = fields[v][0].field
    21. formChild.scrollToField(PropName)
    22. errListMsg.value = fields[v][0].message
    23. }
    24. })
    25. reject()
    26. }
    27. })
    28. })
    29. resultArr.push(result)
    30. }
    31. //提交按钮事件
    32. const taskFun = ()=>{
    33. //获取该子组件暴露出来的form 的 ref
    34. const approvalRefChild = approvalRef.value.forms
    35. const approvalRefChild2 = approvalRef2.value.ruleFormRef
    36. //调用上面创建好的方法
    37. checkForm(approvalRefChild)
    38. checkForm(approvalRefChild2)
    39. Promise.all(resultArr).then((results)=>{
    40. console.log('这里是接口请求');
    41. //校验通过
    42. }).catch(err=>{
    43. //校验不通过提示
    44. console.log(errListMsg.value);
    45. })
    46. resultArr=[]//每次请求完要清空数组
    47. errListMsg.value=""//提示也需要清空
    48. }
    49. </script>
    50. <template>
    51. <childForm ref="approvalRef"></childForm>
    52. <childForm2 ref="approvalRef2"></childForm2>
    53. <button @click="taskFun">提交</button>
    54. </template>

    子组件一:

    这个是表格可以增删改的情况,对表格添加输入校验

    1. <script setup lang="ts">
    2. import {ref, reactive} from 'vue'
    3. import type { FormInstance } from 'element-plus'
    4. const forms = ref<FormInstance>()
    5. let info:any = reactive({
    6. data:[{name:'1'}]
    7. })
    8. const formRules = reactive({
    9. name: [{ required: true, message: '请输入姓名', trigger: 'change' }],
    10. role: [{ required: true, message: '请选择', trigger: 'blur' }]
    11. })
    12. defineExpose({
    13. forms
    14. })
    15. </script>
    16. <template>
    17. <el-form :model="info" ref="forms">
    18. <el-table
    19. ref="tableRef"
    20. :data="info.data"
    21. border>
    22. <el-table-column align="center" property="name" label="*姓名">
    23. <template #default="{row,$index}">
    24. <el-form-item :prop="`data[${$index}].name`" :rules="formRules.name">
    25. <el-input placeholder="请输入姓名" v-model="info.data[$index].name" />
    26. </el-form-item>
    27. </template>
    28. </el-table-column>
    29. <el-table-column align="center" property="role" label="角色">
    30. <template #default="{row,$index}">
    31. <el-form-item :prop="`data[${$index}].role`" :rules="formRules.role">
    32. <el-input placeholder="请输角色" v-model="info.data[$index].role" />
    33. </el-form-item>
    34. </template>
    35. </el-table-column>
    36. </el-table>
    37. </el-form>
    38. </template>

    子组件二:

    这个是普通的form表单情况

    1. <template>
    2. 第二个组件
    3. <el-form
    4. ref="ruleFormRef"
    5. :model="ruleForm"
    6. :rules="rules"
    7. label-width="120px"
    8. class="demo-ruleForm"
    9. :size="formSize"
    10. status-icon
    11. >
    12. <el-form-item label="Activity name" prop="name">
    13. <el-input v-model="ruleForm.name" />
    14. </el-form-item>
    15. </el-form>
    16. </template>
    17. <script lang="ts" setup>
    18. import { reactive, ref } from 'vue'
    19. import type { FormInstance, FormRules } from 'element-plus'
    20. interface RuleForm {
    21. name: string
    22. }
    23. const formSize = ref('default')
    24. const ruleFormRef = ref<FormInstance>()
    25. const ruleForm = reactive<RuleForm>({
    26. name: 'Hello'
    27. })
    28. const rules = reactive<FormRules<RuleForm>>({
    29. name: [
    30. { required: true, message: '请输入Activity name', trigger: 'blur' },
    31. { min: 3, max: 5, message: '长度再3-5位', trigger: 'blur' },
    32. ]
    33. })
    34. defineExpose({ruleFormRef})
    35. </script>

    注意:

    1、子组件中的form要添加ref属性,并使用defineExpose暴露出去,这样父组件才能获取到子组件中的ref,才能进行校验

    2、当对表格输入内容做校验时prop和v-model绑定的是同一个才能校验通过

    3、当发现校验一直不通过时可以查看控制台打印的的结果,看哪个校验没通过

    校验不通过

     

     

  • 相关阅读:
    Textbooks Are All You Need
    数据库和缓存如何保证一致性?
    Python 进程和线程详解(multiprocessing、threading)
    GSMA SGP.01协议学习
    SpringBoot 基础知识汇总 (史上最全)
    苍穹外卖--实现照片上传
    基于JAVA新冠疫苗接种管理系统设计与实现
    智安网络|探索人机交互的未来:自然语言处理的前沿技术
    手撕520页PDF高级文档,成功“挤掉”7年开发架构师,牛逼
    Hadoop学习总结(搭建Hadoop集群(完全分布式模式))
  • 原文地址:https://blog.csdn.net/liuzaixi/article/details/134511333