詳解element-ui設(shè)置下拉選擇切換必填和非必填
➢ 需求
默認(rèn)都是必選
下拉選擇的時(shí)候
選擇必填,活動(dòng)名稱為必填,需要校驗(yàn)和顯示*
選擇非必填,活動(dòng)名稱不做校驗(yàn),隱藏*

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

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

貼上代碼
data() {
// 驗(yàn)證活動(dòng)名稱的函數(shù)
let validateName = (rule, value, callback) => {
// 當(dāng)活動(dòng)名稱為空值且為必填時(shí),拋出錯(cuò)誤,反之通過校驗(yàn)
if (this.ruleForm.name === "" && this.isHaveTo) {
callback(new Error("請(qǐng)輸入活動(dòng)名稱"));
} else {
callback();
}
};
return {
ruleForm: {
name: "",
region: ""
},
rules: {
name: [{ validator: validateName }],
region: [
{ required: true, message: "請(qǐng)選擇類型", 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="活動(dòng)名稱" prop="name" :required="isHaveTo">
<el-input v-model="ruleForm.name"></el-input>
</el-form-item>
<el-form-item label="活動(dòng)區(qū)域" prop="region">
<el-select v-model="ruleForm.region" placeholder="請(qǐng)選擇活動(dòng)區(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() {
// 驗(yàn)證活動(dòng)名稱的函數(shù)
let validateName = (rule, value, callback) => {
// 當(dāng)活動(dòng)名稱為空值且為必填時(shí),拋出錯(cuò)誤,反之通過校驗(yàn)
if (this.ruleForm.name === "" && this.isHaveTo) {
callback(new Error("請(qǐng)輸入活動(dòng)名稱"));
} else {
callback();
}
};
return {
ruleForm: {
name: "",
region: ""
},
rules: {
name: [{ validator: validateName }],
region: [
{ required: true, message: "請(qǐng)選擇類型", 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>
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
vue實(shí)現(xiàn)滑動(dòng)超出指定距離回頂部功能
這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)滑動(dòng)超出指定距離回頂部功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-07-07
elementUI中input回車觸發(fā)頁(yè)面刷新問題與解決方法
這篇文章主要給大家介紹了關(guān)于elementUI中input回車觸發(fā)頁(yè)面刷新問題與解決方法,文中通過實(shí)例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用elementUI具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2023-07-07
vue實(shí)現(xiàn)小球滑動(dòng)交叉效果
這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)小球滑動(dòng)交叉,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09
Vue項(xiàng)目查看當(dāng)前使用的elementUI版本的方法
今天小編就為大家分享一篇Vue項(xiàng)目查看當(dāng)前使用的elementUI版本的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-09-09
Vue3將虛擬節(jié)點(diǎn)渲染到網(wǎng)頁(yè)初次渲染詳解
這篇文章主要為大家介紹了Vue3將虛擬節(jié)點(diǎn)渲染到網(wǎng)頁(yè)初次渲染詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-03-03
VUE使用draggable實(shí)現(xiàn)組件拖拽
這篇文章主要為大家詳細(xì)介紹了VUE使用draggable實(shí)現(xiàn)組件拖拽,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-04-04

