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' },
    
                    }
                },
    	}
    }
相关推荐
Mintopia12 分钟前
🚀 一文看懂 “Next.js 全栈 + 微服务 + GraphQL” 的整体样貌
前端·javascript·全栈
Mintopia15 分钟前
🧬 医疗Web场景下,AIGC的辅助诊断技术边界与伦理
前端·javascript·aigc
半桶水专家19 分钟前
父子组件通信详解
开发语言·前端·javascript
Watermelo61722 分钟前
从vw/h到clamp(),前端响应式设计的痛点与进化
前端·javascript·css·算法·css3·用户界面·用户体验
Moment28 分钟前
快到  2026  年了:为什么我们还在争论  CSS 和 Tailwind?
前端·javascript·css
梵得儿SHI39 分钟前
Vue 核心语法详解:模板语法中的绑定表达式与过滤器(附 Vue3 替代方案)
前端·javascript·vue.js·插值语法·vue模板语法·绑定表达式·过滤器机制
江城开朗的豌豆42 分钟前
TypeScript枚举:让你的代码更有"选择权"
前端·javascript
江城开朗的豌豆1 小时前
TypeScript接口:打造你的代码“契约”之道
前端·javascript
江城开朗的豌豆1 小时前
TypeScript类:面向对象编程的超级武器
前端·javascript
鹏多多1 小时前
React项目使用useMemo优化性能指南和应用场景
前端·javascript·react.js