element form rules 验证数组对象属性时如何写判断规则

  • 需求:一个el-form-item里放了2个下拉选择框,规定是最少选择一个,最多这俩都选择值;下拉框的值设置为对象了,所以这俩select的值组成了一个数组里的两个对象

  • 逻辑:感觉只需要把第一个下拉框值(即数组【0】)设置为必选属性,对起属性值进行判断,为空则报错

  • 知识点:elemenr的rules判断规则,如果是对对象的某个属性进行判断,需要双引号加改对象属性键名el-form-item 上的prop 属性设置为需校验的字段名即可。

  • 另外:如果需要select的值为对象,需要在select 上 加上value-key="对象里属性的唯一值一般写userId"el-option的:key="item.userId这俩值所用的属性名要一致

  • 代码

    js 复制代码
    	// html
    	<el-form-item label="参与人"  prop="auditors[0].userId">
    	                        <el-select v-model="form.data.auditors[0]" value-key="userId">
    	                            <el-option v-for="item in classname" :key="item.userId" :label="item.userName" :value="item"></el-option> 
    	                        </el-select>
    	                        <el-select  v-model="form.data.auditors[1]" value-key="userId" >
    	                            <el-option v-for="item in classname" :key="item.userId" :label="item.userName" :value="item"></el-option>                         
    	                        </el-select>
    	                    </el-form-item>
    js 复制代码
    //js
    data(){
    	return {
    	classname:[
    		{
    		    "userId": 1,
    		    "userName": "张三"
    		},
    		{
    		    "userId": 2,
    		    "userName": "lisi"
    		},
    	],
    	form:{
                    
                    data:{
                        auditors:[
                            {userId:null,userName:null},
                            {userId:null,userName:null},
                        ]
                    },
                    rules:{
                        "auditors[0].userId":{ required: true, message: '参与人', trigger: 'change' },
    
                    }
                },
    	}
    }
相关推荐
跳动的梦想家h10 小时前
环境配置 + AI 提效双管齐下
java·vue.js·spring
冰暮流星11 小时前
javascript之二重循环练习
开发语言·javascript·数据库
Mr Xu_11 小时前
Vue 3 中 watch 的使用详解:监听响应式数据变化的利器
前端·javascript·vue.js
一 乐12 小时前
校园二手交易|基于springboot + vue校园二手交易系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端
科技D人生12 小时前
Vue.js 学习总结(20)—— Vue-Office 实战:word、pdf、excel、ppt 多种文档的在线预览
vue.js·word·vue-pdf·stylesheet·docx-preview·vue-office
vx1_Biye_Design12 小时前
基于Spring Boot+Vue的学生管理系统设计与实现-计算机毕业设计源码46223
java·vue.js·spring boot·spring·eclipse·tomcat·maven
vx_Biye_Design12 小时前
基于Spring Boot+vue的湖北旅游景点门票预约平台的设计--毕设附源码29593
java·vue.js·spring boot·spring cloud·servlet·eclipse·课程设计
hedley(●'◡'●)12 小时前
基于cesium和vue的大疆司空模仿程序
前端·javascript·vue.js·python·typescript·无人机
qq5_81151751512 小时前
web城乡居民基本医疗信息管理系统信息管理系统源码-SpringBoot后端+Vue前端+MySQL【可直接运行】
前端·vue.js·spring boot
百思可瑞教育12 小时前
构建自己的Vue UI组件库:从设计到发布
前端·javascript·vue.js·ui·百思可瑞教育·北京百思教育