詳解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ù)下拉框選擇的值來(lái)決定是為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ī)則
注意,新的問題來(lái)了
在選擇必填時(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-07elementUI中input回車觸發(fā)頁(yè)面刷新問題與解決方法
這篇文章主要給大家介紹了關(guān)于elementUI中input回車觸發(fā)頁(yè)面刷新問題與解決方法,文中通過實(shí)例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用elementUI具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2023-07-07vue實(shí)現(xiàn)小球滑動(dòng)交叉效果
這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)小球滑動(dòng)交叉,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09Vue項(xiàng)目查看當(dāng)前使用的elementUI版本的方法
今天小編就為大家分享一篇Vue項(xiàng)目查看當(dāng)前使用的elementUI版本的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧2018-09-09Vue3將虛擬節(jié)點(diǎn)渲染到網(wǎng)頁(yè)初次渲染詳解
這篇文章主要為大家介紹了Vue3將虛擬節(jié)點(diǎn)渲染到網(wǎng)頁(yè)初次渲染詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-03-03VUE使用draggable實(shí)現(xiàn)組件拖拽
這篇文章主要為大家詳細(xì)介紹了VUE使用draggable實(shí)現(xiàn)組件拖拽,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-04-04