問題:選擇switch 改變 ruleForm.delivery 的值,動態實現校驗生效
1、去除rules中需要動態校驗的字段規則
// 去除前
rules: {
name: [
{ required: true,message: "請輸入名稱",trigger: "blur" }
],
region: [
{ required: true, message: "請選擇條件", trigger: "blur" }
]
}
// 去除后
rules: {
name: [
{ trigger: "blur" }
],
region: [
{ required: true, message: "請選擇條件", trigger: "blur" }
]
}
2、在prop字段為name的form-item上,添加required屬性
下面代碼isHaveTo為新字段,根據下拉框選擇的值來決定是為true還是false
<el-form-item label="名稱" prop="name" :required="isHaveTo">
<el-input v-model="ruleForm.name"></el-input>
</el-form-item>
3、計算屬性,新增字段isHaveTo
下拉選擇框為1是非必填,其他都是必填,包括默認
computed: {
isHaveTo: function() {
return this.ruleForm.region !== 1;
}
},
4、設置錯誤提示,使用自定義函數控制流程,把name字段重新加回去rules
注意是函數
data() {
// 驗證名稱的函數
let validateName = (rule, value, callback) => {
// 當名稱為空值且為必填時,拋出錯誤,反之通過校驗
if (this.ruleForm.name === "" && this.isHaveTo) {
callback(new Error("請輸入名稱"));
} else {
callback();
}
};
return {
ruleForm: {
name: "",
region: ""
},
rules: {
name: [{trigger: "blur" , validator: validateName }],
region: [
{ required: true, message: "請選擇條件", trigger: "blur" }
]
}
};
},
自定義函數validator在 return 之前
vue代碼:
<template>
<div>
<el-form
:model="ruleForm"
:rules="rules"
ref="ruleForm"
label-width="100px"
class="demo-ruleForm"
>
<el-form-item label="名稱" prop="name" :required="isHaveTo">
<el-input v-model="ruleForm.name"></el-input>
</el-form-item>
<el-form-item label="條件" prop="region">
<el-select v-model="ruleForm.region" placeholder="請選擇條件" style="width:100%">
<el-option label="必填" value="0"></el-option>
<el-option label="非必填" value="1"></el-option>
</el-select>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="submitForm('ruleForm')">立即創建</el-button>
</el-form-item>
</el-form>
</div>
</template>
<script>
export default {
name: "HelloWorld",
data() {
// 驗證名稱的函數
let validateName = (rule, value, callback) => {
// 當名稱為空值且為必填時,拋出錯誤,反之通過校驗
if (this.ruleForm.name === "" && this.isHaveTo) {
callback(new Error("請輸入名稱"));
} else {
callback();
}
};
return {
ruleForm: {
name: "",
region: ""
},
rules: {
name: [{ trigger: "blur",validator: validateName }],
region: [
{ required: true, message: "請選擇條件", trigger: "blur" }
]
}
};
},
computed: {
isHaveTo: function() {
return this.ruleForm.region !== 1;
}
},
methods: {
submitForm(formName) {
this.$refs[formName].validate(valid => {
if (valid) {
console.log(`已提交表單`);
} else {
console.log("error submit!!");
return false;
}
});
}
}
};
</script>