el-form-item下多个form-item项校验(循环校验)

文章介绍了如何使用Vue.js实现动态添加自定义字段的表单,并进行验证。通过el-form-item组件,结合v-for循环,动态生成表单元素,并利用prop和rules进行表单验证。当key或value为空时,会触发警告信息。同时,提供了添加和删除字段的功能限制,最多允许新增3条记录。
摘要由CSDN通过智能技术生成

el-form-item下多个form-item项校验

去年在编写一个页面的时候,要求自定义字段,可以动态的循环添加,还要增加表单验证,在这块的内容的编写不太熟练,最后参照着网上的一些资料,主要参考这个博主https://blog.csdn.net/l508742729/article/details/108286071的博客,完成了这一项任务的开发。具体实现页面如下所示。
在这里插入图片描述
在这里插入图片描述
前端代码实现如下所示,主要是通过prop来确定好每一个表单验证的值

   <el-form-item label="自定义字段:" class="is-required" >
      <div v-for="(item, index) in add.custom" :key="index">
         <el-form-item :rules="rules.key" :prop="'custom.' + index + '.key'">
            <el-input v-model.trim="item.key" placeholder="Key"  style="width:100px">
            </el-input>
         </el-form-item>
         <el-form-item :rules="rules.value" :prop="'custom.' + index + '.value'">
            <el-input v-model.trim="item.value" placeholder="Value"  style="width:150px; margin-left: -5px;" @change.native="change(item)">
           </el-input>
        </el-form-item>
            <i class="el-icon-plus changecolor" @click="addItem(add.custom.length)"></i>
            <i class="el-icon-minus changecolor" v-if="index !== 0" @click="deleteItem(item,index)"></i>
            <br />
      </div>
   </el-form-item>

逻辑代码部分

<script>
export default {
    name:'add',
    data() {
        return {
            add:{
                custom: [
                    {
                        key: '',
                        value: '',
                    }
                ]
            },
            rules: {
              key:{
                required: true,
                trigger: 'change',
                message:'key值不能为空'
              },
              value:{
                required: true,
                trigger: 'change',
                message:'value值不能为空'
              },
            },
        }
    },
    methods: {
        addItem(length){
            if (length >= 3) {
                this.$message({
                    type: 'warning',
                    message: '最多可新增3条!'
                })
            } else {
                this.add.custom.push({
                    key: '',
                    value: '',
                })
            }
        },
        deleteItem(item, index) {
            this.add.custom.splice(index, 1)
        },
        change(item){
          if(item.key==''){
                this.$message({
                    type: "warning",
                    message: "key值为空,不能保存"
                })
            item.value = ''
          }
        },
    },
}
</script>

如此,开发就完成了

el-formElement UI 提供的表单组件,用于快构建表单界面。el-form 表单校验是指对表单中的输入内容进行验证,确保用户输入的数据符合预期的格式和要求。 在 el-form 中进行表单校验时,可以通过设置 rules 属性来定义校验规则。每个表单el-form-item)可以设置 prop 属性来指定校验规则所对应的字段名。校验规则可以是一个数组,每个规则对象包含 validator 和 message 两个属性,validator 是一个函数,用于自定义校验逻辑,message 是校验失败时显示的错误提示信息。 以下是 el-form 表单校验的示例代码: ```html <template> <el-form :model="form" :rules="rules" ref="form"> <el-form-item label="用户名" prop="username"> <el-input v-model="form.username"></el-input> </el-form-item> <el-form-item label="密码" prop="password"> <el-input type="password" v-model="form.password"></el-input> </el-form-item> <el-form-item> <el-button type="primary" @click="submitForm">提交</el-button> </el-form-item> </el-form> </template> <script> export default { data() { return { form: { username: '', password: '' }, rules: { username: [ { required: true, message: '请输入用户名', trigger: 'blur' }, { min: 3, max: 10, message: '用户名长度在 3 到 10 个字符之间', trigger: 'blur' } ], password: [ { required: true, message: '请输入密码', trigger: 'blur' }, { min: 6, max: 20, message: '密码长度在 6 到 20 个字符之间', trigger: 'blur' } ] } }; }, methods: { submitForm() { this.$refs.form.validate(valid => { if (valid) { // 表单校验通过,提交表单 // TODO: 提交表单的逻辑 } else { // 表单校验不通过,显示错误信息 return false; } }); } } }; </script> ``` 在上述示例中,通过设置 rules 属性来定义了两个校验规则,分别对应用户名和密码字段。在 submitForm 方法中,通过调用 this.$refs.form.validate 方法来触发表单校验校验结果会通过回调函数的参数 valid 返回,如果 valid 为 true,则表示表单校验通过,可以提交表单;如果 valid 为 false,则表示表单校验不通过,需要显示错误信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值