关于iview中表单Form自定义验证

31 篇文章 0 订阅
12 篇文章 0 订阅

目的:实现使用iview中表单的验证自己想要的结果

结果:网上找到合适方法validator

步骤:

1.在form中设置好要验证的值

            <FormItem label="分类:" prop="MenuClassifyId">
            <Select v-model="formItem.MenuClassifyId">
             <Option :value="11">1111</Option>

            <Option :value="22">222</Option>
            </Select>

2.在vue中data(){}写验证函数。官网有案例:https://www.iviewui.com/components/form

  export default {
    data () {
    var that=this
        const validateMenuClassifyId = (rule, value, callback) => {
         console.log("单个表单验证")
           console.log(value) //value是对应的ormItem.MenuClassifyId值
                if (value === ''||value ===0) {     //写逻辑从而达到验证值
                    callback(new Error('请选择分类!'));   //callback()暂时理解为回调,验证后回调给界面的信息
                } else {
                    callback();   //默认回调,没有异常值
                }
            };

 

3.在form中的验证调用2的函数。

MenuClassifyId:[

                        //required显示*号,validator验证回到的函数,validateMenuClassifyId自定义验证函数,

                   //trigger暂时理解为验证值是否为空                

   { required: true,validator: validateMenuClassifyId, trigger: 'blur' }
                    ],

4.这样设置好,form表单就会自动输入提交时验证函数validateMenuClassifyId。

     that.$refs[name].validate((valid) => {
           console.log(valid)  //验证全部表单,validateMenuClassifyId回到有错误则会valid返回false。
                    if (valid) {}else{}

}

疑问:在验证中如果每个form验证调用同一个验证时只会验证一次。

            <FormItem label="简介:">
            <Input v-model="formItem.About" placeholder="简短介绍" prop="Name"></Input>
            </FormItem>
             <FormItem label="销售量:" >
             <InputNumber v-model="formItem.Sale" disabled  prop="Name"></InputNumber>
            </FormItem>

///

                    Name: [
                        { required: true, message: '不能为空!', trigger: 'blur' }
                    ],

官网给出了一个详细的验证说明:https://github.com/yiminghe/async-validator

但是我不会用。只能网上一点一点找方法最后找到上面自己提炼后的方法。

看不懂的可以留言。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

智慧方

开发程序不易

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值