網(wǎng)站首頁(yè) 編程語(yǔ)言 正文
業(yè)務(wù)場(chǎng)景:根據(jù)form表單中的某些下拉框選中值,動(dòng)態(tài)切換一些屬性的必填校驗(yàn)。
<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ò)誤,反之通過(guò)校驗(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>
效果圖:
當(dāng)活動(dòng)區(qū)域非必填時(shí),活動(dòng)名稱取消必填校驗(yàn),否則活動(dòng)名稱必填。
原文鏈接:https://blog.csdn.net/weixin_46060121/article/details/125797844
相關(guān)推薦
- 2022-05-20 Redis 做接口限流,一個(gè)注解的事
- 2022-04-03 sqoop如何指定pg庫(kù)的模式(方法詳解)_相關(guān)技巧
- 2022-12-14 C++?Boost?ScopeExit超詳細(xì)講解_C 語(yǔ)言
- 2022-04-28 SpringBoot?整合mongoDB并自定義連接池的示例代碼_MongoDB
- 2022-11-27 VsCode運(yùn)行html界面的實(shí)戰(zhàn)步驟_其它綜合
- 2022-05-12 Kotlin 擴(kuò)展函數(shù) 之 可空
- 2022-11-06 React如何接收excel文件下載導(dǎo)出功能封裝_React
- 2023-11-11 Jetson nano 安裝swapfile 解決Cannot allocate memory 問(wèn)題
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過(guò)濾器
- Spring Security概述快速入門(mén)
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡(jiǎn)單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支