form表单校验对象中的对象的属性 / 根据表单中某一个数据动态添加其他项是否必填

<template>

<el-form ref="form" :model="form" :rules="rules" label-width="120px">

<div class="info-tag">表单信息</div>

<el-row :gutter="20">

<el-col :span="8">

<el-form-item label="数据1" prop="test1" >

<el-select v-model="form.test1" placeholder="请选择test1" style="width: 100%" @change="test1Change">

<el-option v-for="dict in dictList" :key="dict.value" :label="dict.label"

:value="dict.value"></el-option>

</el-select>

</el-form-item>

</el-col>

<el-col :span="8">

<el-form-item label="数据2" prop="child.test2"

:rules="setRules(form.test1,'child.test2')">

<el-input v-model="form.child.test2" placeholder="请输入test2" />

</el-form-item>

</el-col>

<el-col :span="24">

<el-form-item label="数据3" prop="child.test3"

:rules="setRules(form.test1,'child.test3')">

<el-input v-model="form.child.test3" placeholder="请输入test3" />

</el-form-item>

</el-col>

</el-row>

</el-form>

</template>

export default {

data(){

return{

// 表单参数

form: {

test1:null,

child: {

test2:null,

test3:null,

}

},

// 表单校验

rules: {

test1: [{required: true, message: "test1不能为空", trigger: "change"}],

'child.test2': [{required: true, message: "test2不能为空", trigger: "blur"}],

'child.test3': [{required: true, message: "test3不能为空", trigger: "blur"}],

}

}

}

methods:{

test1Change(){

// 非必填 清除校验结果

if(e === '3'){

this.$refs.form.clearValidate()

}

},

// 根据数据1选择结果 判断key对应项是否必填

setRules(type,key){

if(type === '1'|| type === '2'){//必填

this.rules[key][0].required = true

return this.rules[key]

}else {// 非必填

this.rules[key][0].required = false

return [{required: false}]

}

},

}

}

相关推荐
xkxnq5 小时前
第一阶段:Vue 基础入门(第 12天)
前端·javascript·vue.js
q_19132846955 小时前
基于Springboo和vue开发的企业批量排班系统人脸识别考勤打卡系统
前端·javascript·vue.js·spring boot·mysql·毕业设计·人脸识别
小二·5 小时前
Vue 前端性能优化终极指南:Lighthouse 100 分实战(Vue 3 + Vite)
前端·vue.js·性能优化
大鸡爪6 小时前
基于PDF.js的安全PDF预览组件实现:从虚拟滚动到水印渲染
vue.js
myltx6 小时前
node-sass 迁移 sass(dart-sass) 后样式报错?用 loader 先把构建救回来
vue.js·前端工程化
用户0203388613146 小时前
Vue以及ElementPlus学习
vue.js
用户841794814566 小时前
vxe-table 个性化列自定义列弹出层修改高度、修改最大高度不自动适应表格高度的方法
vue.js
北辰alk6 小时前
Vue 数据响应式探秘:如何让数组变化无所遁形?
vue.js
San306 小时前
告别全局污染:深入解析现代前端的模块化 CSS 演进之路
css·vue.js·react.js
如果你好6 小时前
# Vue 事件系统核心:createInvoker 函数深度解析
前端·javascript·vue.js