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.ruleskey0.required = true

return this.ruleskey

}else {// 非必填

this.ruleskey0.required = false

return {required: false}

}

},

}

}

相关推荐
奋斗吧程序媛3 小时前
补充一个小知识点:有关@click.native
前端·vue.js
英勇无比的消炎药3 小时前
一行命令背后:TinyRobot CLI 如何重构 AI 对话接入的效率范式
vue.js·aigc
jay神5 小时前
基于 FastAPI + Vue 的宠物领养管理系统
前端·vue.js·python·毕业设计·fastapi·宠物
一杯奶茶¥5 小时前
水果销售网站 CRM客户信息管理系统 超市管理系 酒店管理系统 健身房管理系统 在线音乐网站 校园招聘系统
java·vue.js·spring boot·mysql·spring·java项目
英勇无比的消炎药6 小时前
一站式搞定品牌风格:TinyRobot 主题定制从入门到精通
vue.js
尽欢i8 小时前
Vue3 customRef 封神教程:防抖、本地存储、自动埋点一套搞定,模板干干净净
前端·javascript·vue.js
因_崔斯汀8 小时前
Vue 模板编译:HTML 是怎么变成 JS 的?
前端·vue.js
英勇无比的消炎药9 小时前
样式随心定制:TinyRobot 样式覆写与 CSS 变量实战解析
vue.js
疯狂的魔鬼9 小时前
多角色督办任务详情页:从权限矩阵到组件拆分的完整实现
前端·vue.js·架构
英勇无比的消炎药9 小时前
拆解内核:深入分析 TinyRobot 输入区组件设计与实现原理
vue.js