詳解element-ui設置下拉選擇切換必填和非必填
➢ 需求
默認都是必選
下拉選擇的時候
選擇必填,活動名稱為必填,需要校驗和顯示*
選擇非必填,活動名稱不做校驗,隱藏*

➢ 初始校驗規(guī)則
經(jīng)測試,網(wǎng)上其他的方式都沒有實現(xiàn)需求,動態(tài)切換rules中的required沒有作用
因為按照以下的寫法的話,element-ui在組件初始化后校驗規(guī)則就定型了,切換也沒用
rules: {
name: [
{ required: true, message: "請輸入名稱", trigger: "blur" }
],
region: [
{ required: true, message: "請選擇類型", trigger: "blur" }
]
}
➢ 解決方案
第一步:
去除rules中需要動態(tài)校驗的字段規(guī)則
去除name
rules: {
region: [
{ required: true, message: "請選擇類型", trigger: "blur" }
]
}
第二步:
在字段為name的form-item上,添加required屬性
下面代碼isHaveTo為新字段,根據(jù)下拉框選擇的值來決定是為true還是false
<el-form-item label="活動名稱" prop="name" :required="isHaveTo"> <el-input v-model="ruleForm.name"></el-input> </el-form-item>
第三步:
計算屬性,新增字段isHaveTo
下拉選擇框非必須是為1,其他都是必填,包括默認
<el-form-item label="活動名稱" prop="name" :required="isHaveTo"> <el-input v-model="ruleForm.name"></el-input> </el-form-item>
效果如圖:
下拉切換,*號顯隱,提交時也有不同規(guī)則
注意,新的問題來了
在選擇必填時,沒有了之前的錯誤提示文字,而是element自帶的提示

第四步:
設置錯誤提示
使用自定義函數(shù)控制流程
把name字段重新加回去rules
注意是函數(shù){ validator: validateName }
rules: {
name: [{ validator: validateName }],
region: [
{ required: true, message: "請選擇類型", trigger: "blur" }
]
}
然后設置函數(shù)validateName
可以看到,必填時按照我們設置的提示語提示,非必填時,校驗通過

貼上代碼
data() {
// 驗證活動名稱的函數(shù)
let validateName = (rule, value, callback) => {
// 當活動名稱為空值且為必填時,拋出錯誤,反之通過校驗
if (this.ruleForm.name === "" && this.isHaveTo) {
callback(new Error("請輸入活動名稱"));
} else {
callback();
}
};
return {
ruleForm: {
name: "",
region: ""
},
rules: {
name: [{ validator: validateName }],
region: [
{ required: true, message: "請選擇類型", trigger: "blur" }
]
}
};
},
➢ 完整demo代碼
demo使用vue-cli,引入element-ui
核心代碼參考如下:
<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="活動區(qū)域" prop="region">
<el-select v-model="ruleForm.region" placeholder="請選擇活動區(qū)域" 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')">立即創(chuàng)建</el-button>
</el-form-item>
</el-form>
</div>
</template>
<script>
export default {
name: "HelloWorld",
data() {
// 驗證活動名稱的函數(shù)
let validateName = (rule, value, callback) => {
// 當活動名稱為空值且為必填時,拋出錯誤,反之通過校驗
if (this.ruleForm.name === "" && this.isHaveTo) {
callback(new Error("請輸入活動名稱"));
} else {
callback();
}
};
return {
ruleForm: {
name: "",
region: ""
},
rules: {
name: [{ 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>
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
elementUI中input回車觸發(fā)頁面刷新問題與解決方法
這篇文章主要給大家介紹了關于elementUI中input回車觸發(fā)頁面刷新問題與解決方法,文中通過實例代碼介紹的非常詳細,對大家學習或者使用elementUI具有一定的參考學習價值,需要的朋友可以參考下2023-07-07
Vue3將虛擬節(jié)點渲染到網(wǎng)頁初次渲染詳解
這篇文章主要為大家介紹了Vue3將虛擬節(jié)點渲染到網(wǎng)頁初次渲染詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-03-03

