element ui 循环表单验证提交展示

1.表单

<el-form v-for="(item , index) in mainInfo" :model="mainInfo[index]" :ref="'mainInfoForm'+index" :rules="mainInfoRules" label-width="160px">
    <el-tag type="info" style="margin-left: 160px;margin-bottom: 2px">企业{{index+1}}</el-tag>
    <el-link type="primary" v-if="item.enterpriseId != enterpriseNo" style="float: right;margin-right:220px;" @click="deleteEnterpriseInfo(item.enterpriseId,index)">删除</el-link>
    <el-link type="primary" :class="`${item.enterpriseId != enterpriseNo?'btnFlag1':'btnFlag2'}`" @click="updateEnterpriseInfo(item.enterpriseId,index)">{{item.isEdite?'编辑':'保存'}}</el-link>
    <el-form-item label="企业注册名称" prop="enterpriseName">
        <el-input v-model="item.enterpriseName" :readonly="item.isEdite" placeholder="请填入企业注册名称" style="width: 62%;"></el-input>
        <el-checkbox v-model="item.isCheck" :disabled="item.isShowRegistered==1 || item.isEdite ?true:false" @change="toggleCheckbox(index)" style="margin-left:10px;">&nbsp;企业内部默认显示此名称</el-checkbox>
    </el-form-item>

    <el-form-item>
        <el-button type="primary" :disabled="item.isRealed==1 || item.enterpriseId==''?true:false" @click="getIdentityUrl(item.isRealed)" style="width: 100%;">{{item.isRealed==1?'已实名认证':'申请实名认证'}}</el-button>
        <el-tag type="info" style="width: 100%;text-align: center;">完成企业认证后可开通您需要的所有业务模块,并且能申请电子印章</el-tag>
    </el-form-item>

    <el-form-item label="法人代表/负责人" v-if="item.enterpriseId == ''" prop="corporate">
        <el-input v-model="item.corporate" :readonly="item.isEdite" placeholder="请填入法人代表/负责人"></el-input>
    </el-form-item>
    <el-form-item label="法人/负责人身份证号" v-if="item.enterpriseId == ''" prop="corporateCardNo">
        <el-input v-model="item.corporateCardNo" :readonly="item.isEdite" placeholder="请填入法人/负责人身份证号"></el-input>
    </el-form-item>
    <el-form-item label="企业英文/中文名称" prop="">
        <el-input v-model="item.enterpriseDisplayName" :readonly="item.isEdite" placeholder="请填入企业英文/中文名称"></el-input>
    </el-form-item>
    <el-form-item label="国家/地区" prop="enterpriseArea">
        <el-select v-model="item.enterpriseArea" :disabled="item.isEdite" placeholder="请选择企业注册所在地" :class="prefix + '-select'">
            <el-option label="中国大陆" value="中国大陆"></el-option>
            <el-option label="中国香港" value="中国香港"></el-option>
            <el-option label="中国澳门" value="中国澳门"></el-option>
            <el-option label="中国台湾" value="中国台湾"></el-option>
        </el-select>
    </el-form-item>
    <el-form-item label="营业执照/工商注册号" prop="businessNo">
        <el-input v-model="item.businessNo" :readonly="item.isEdite" placeholder="请填入企业营业执照/工商注册号"></el-input>
    </el-form-item>
    <el-form-item label="注册地址" prop="registerAddress">
        <el-input v-model="item.registerAddress" :readonly="item.isEdite" placeholder="请填入企业注册地址"></el-input>
    </el-form-item>
    <el-divider v-if="index != mainInfo.length -1"></el-divider>
</el-form>

2.script

export default {
    data() {
        return { 
            mainInfo:[
                {
    enterpriseId:' ',
    enterpriseName:'',
    corporate:'',
    corporateCardNo:'',
    enterpriseDisplayName:'',
    enterpriseArea:'',
    businessNo:'',
    registerAddress:'',
    isEdite:true,
              }
] ,
mainInfoRules: {
    enterpriseName: [
        { required: true, message: "企业名称不能为空", trigger: "blur" }
    ],
    enterpriseArea: [
        { required: true, message: "国家/地区不能为空", trigger: "blur" }
    ],
    businessNo: [
        { required: true,validator: checkBusinessNo, trigger: "blur" }
    ],
    corporate: [
        { required: true, message: "法人代表/负责人不能为空", trigger: "blur" }
    ],
    corporateCardNo: [
        { required: true,validator: checkCardNo, trigger: "blur" }
    ],
    registerAddress: [
        { required: true, message: "注册地址不能为空", trigger: "blur" }
    ]
}
  }
    }

}

 

3.新增删除,只需要控制mainInfo这个数组即可

Vue 是一个流行的 JavaScript 框架,用于构建用户界面和单页面应用程序。Element UI 是一个基于 Vue.js 的组件库,提供了丰富的 UI 组件和工具。在 Vue 中使用 Element UI 构建表单,可以通过循环来动态生成表单项并进行验证。 首先,我们可以使用 Vue 的 v-for 指令来循环渲染表单项。通过遍历数据源(如数组或对象)来动态生成表单字段,例如输入框、下拉框、复选框等。这样就可以实现根据数据源的变化而动态生成不同数量的表单项,方便灵活地管理表单内容。 其次,通过 Element UI 提供的验证规则和验证器,可以实现对表单的循环验证。我们可以为每个表单项设置相应的验证规则(如必填、格式验证等),并通过验证器对整个表单进行验证。在循环中,可以动态添加、修改或删除验证规则,以实现对动态生成的表单项的实时验证。 另外,可以利用 Element UI 提供的表单组件和事件处理机制来实现更进一步的表单循环验证。例如,可以监听表单项的输入变化、聚焦和失焦事件,在相应的事件处理函数中进行数据的验证和反馈。这样就可以及时提示用户输入的正确与否,提升用户体验。 总之,使用 Vue 和 Element UI 可以很容易地实现表单的循环验证。通过动态生成表单项、设置验证规则和事件处理,可以灵活地管理和验证表单数据,提供更好的用户交互体验。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值