关于vue elementUi校验slot插槽中的表单项

项目场景:在父组件表单中使用子组件,并使用子组件插槽功能来管理父组件的单个表单项

重点提示:这里要明确一个概念,凡是在组件内插槽的内容都属于组件管理,因此,要校验父组件使用子组件的slot插槽展示表单项,那么这个表单项的校验规则要放在子组件的表单数据中进行管理和校验

解决方案

这里涉及到作用域具名插槽功能,用来将子组件的表单数据传递给父组件

// 子组件
// 表单管理,比如父组件的slot表单项字段是customField,数据源分传递和子组件定义,自行选择

<el-form ref="formRef" :model="formData" :rules="rules">
  <!-- 其他表单项... -->
  <el-form-item prop="customField">
    <!-- 作用域具名插槽,name可以自定义,与父组件一致即可 -->
    <slot name="customField" :formData="formData"></slot>
  </el-form-item>
  <!-- 其他表单项... -->
</el-form>

export default {
  props: {
    // 数据源1:使用父组件传递的
    formData: {
      type: Object,
      default: () => ({})
    }
  },
  data() {
    return {
      // 数据源2:使用子组件自定义的
      formData: {
        customField
      },
      rules: {
        customField: [
          { required: true, message: '此字段为必填项', trigger: 'blur' }
        ]
      }
    };
  },
  methods: {
    // 子组件保存提交校验
    validateForm() {
      this.$refs.formRef.validate((valid) => {
        if (valid) {
          console.log('表单验证通过');
          // 执行后续逻辑
        } else {
          console.log('表单验证失败');
        }
      });
    }
  }
};
// 父组件 

// 数据源1
<child-component :formData="parentFormData">
  <template #customField="{ formData }">
    <el-input v-model="formData.customField"></el-input>
  </template>
</child-component>

// 数据源2
<child-component>
  <template #customField="{ formData }">
    <el-input v-model="formData.customField"></el-input>
  </template>
</child-component>

相关推荐

  1. 关于vue elementUi校验slot单项

    2024-06-19 07:40:04       8 阅读
  2. VueSlot使用说明

    2024-06-19 07:40:04       30 阅读
  3. VueSlot如何使用

    2024-06-19 07:40:04       25 阅读
  4. vue slot使用

    2024-06-19 07:40:04       16 阅读
  5. slot

    2024-06-19 07:40:04       34 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-06-19 07:40:04       14 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-06-19 07:40:04       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-06-19 07:40:04       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-06-19 07:40:04       18 阅读

热门阅读

  1. 编程用什么电脑不卡的:深度解析与推荐

    2024-06-19 07:40:04       7 阅读
  2. 代码随想录算法训练营第十二天

    2024-06-19 07:40:04       6 阅读
  3. CSS选择器

    2024-06-19 07:40:04       9 阅读
  4. lspci总结

    2024-06-19 07:40:04       6 阅读
  5. 实现ROS中两个里程计数据的转换到同一坐标系下

    2024-06-19 07:40:04       9 阅读
  6. 基础语法总结 —— Python篇

    2024-06-19 07:40:04       5 阅读
  7. Lua迭代器详解(附加红点功能实例)

    2024-06-19 07:40:04       5 阅读
  8. 【C++11】initializer_list详解!

    2024-06-19 07:40:04       6 阅读
  9. QT day4

    QT day4

    2024-06-19 07:40:04      5 阅读
  10. 百度网盘提速攻略:解决限速问题的实用方法

    2024-06-19 07:40:04       8 阅读
  11. vue项目cnpm i 报错

    2024-06-19 07:40:04       5 阅读
  12. 基于springboot的美食推荐商城源码数据库

    2024-06-19 07:40:04       6 阅读