element表单动态控制是否必填

2 篇文章 0 订阅
1 篇文章 0 订阅

问题:有四种发票类型,当类型为纸质专票时,可以不输入校验码,其他三种情况都必须输入校验码。

解决方式:动态控制表单的rules

代码:

...
            <!--            纸质专票无需输入校验码-->
            <el-form-item label="校验码后六位" prop="checkCode"
                          :rules="invoiceInfo.invoiceType == 2 ? [{required: false}]:rules.checkCode">
                <el-input v-model="invoiceInfo.checkCode" autocomplete="off" placeholder="请输入校验码后六位"
                          clearable=""></el-input>
            </el-form-item>
...
data() {
            return {
                ...
                rules: {
                    checkCode: [
                        {required: true, message: '请输入校验码后六位', trigger: 'blur'}
                    ],
                    ...
                }
            }

核心代码:

:rules="invoiceInfo.invoiceType == 2 ? [{required: false}]:rules.checkCode"

根据invoiceInfo.invoiceType的值,改变使用的rules;

页面效果:

切换成纸质专票,小红点消失了。

  • 6
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
ElementPlus是一个基于Vue.js的UI库,提供了丰富的组件和功能。其中,ElementPlus还提供了自定义校验规则的功能。 使用ElementPlus自定义校验规则可以通过以下步骤实现: 1. 在组件中添加自定义校验规则。 ```vue <template> <el-form :model="form" :rules="rules" ref="form"> <el-form-item label="Email" prop="email"> <el-input v-model="form.email"></el-input> </el-form-item> <el-form-item> <el-button type="primary" @click="submitForm">提交</el-button> </el-form-item> </el-form> </template> <script> export default { data() { return { form: { email: "" }, rules: { email: [ { required: true, message: "请输入邮箱", trigger: "blur" }, { validator: this.validateEmail, trigger: "blur" } ] } }; }, methods: { validateEmail(rule, value, callback) { if (!value) { callback(new Error("请输入邮箱")); } else { const emailReg = /^[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(\.[a-zA-Z0-9_-]+)+$/; if (!emailReg.test(value)) { callback(new Error("请输入正确的邮箱")); } else { callback(); } } }, submitForm() { this.$refs.form.validate(valid => { if (valid) { // 校验通过,提交表单 console.log("表单数据:", this.form); } else { // 校验失败,提示错误信息 console.log("校验失败"); } }); } } }; </script> ``` 在上面的代码中,我们使用了`validator`属性来添加自定义校验规则,将`validateEmail`方法作为校验函数传递给`validator`属性。在`validateEmail`方法中,我们使用正则表达式来判断输入的邮箱格式是否正确,如果不正确则返回错误信息,否则返回校验通过的信号。 2. 在`validateEmail`方法中,我们使用了`callback`函数来返回校验结果。当校验结果为`false`时,我们需要传递一个错误信息给`callback`,否则直接调用`callback()`即可。 3. 在方法中,我们使用了`this.$refs.form.validate`来触发表单校验。该方法会返回一个布尔值,表示表单是否校验通过。如果校验通过,我们可以提交表单,否则需要提示错误信息。 总结: 使用ElementPlus自定义校验规则可以为我们提供更加灵活的校验方式,通过`validator`属性和`callback`函数可以实现自定义的校验逻辑。同时,ElementPlus还提供了丰富的校验规则,可以满足我们大多数的校验需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值