• 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、当发现校验一直不通过时可以查看控制台打印的的结果,看哪个校验没通过

    校验不通过

     

     

  • 相关阅读:
    数据库 MVCC 详解
    基于C#+MySQL的停车场管理系统设计与实现
    leetcode 58
    跨平台编译QWT、安装QWT(Windows、Linux、MacOS环境下编译与安装)
    【Redis】Redis 的学习教程(九)之 发布 Pub、订阅 Sub
    让你的相册变成私有云!Synology Photos 的公网访问功能指南
    linux读取U盘操作
    程序员的放肆
    nginx + tomcat 搭建负载均衡、动静分离(tomcat多实例)
    平面和射线交点
  • 原文地址:https://blog.csdn.net/liuzaixi/article/details/134511333