搜索

查看: 3067|回复: 11

[JavaScript] Vue如何使用ElementUI对表单元素进行自定义校验及踩坑

[复制链接]
发表于 2023-5-4 11:48:02 | 显示全部楼层 |阅读模式
Editor 2023-5-4 11:48:02 3067 11 看全部
目录
  • 前言
  • 非空校验
  • 自定义校验
  • 定义自定义校验函数
  • 使用自定义校验函数
  • 总结
    前言
    在使用ElementUI的表单元素时候,除了做一些简单的非空处理校验,在一些特殊的场合,还需要我们做一些自定义校验。
    其实ElementUI不仅提供了基本的非空校验,也对我们提供了自定义检验。
    在使用的时候还是遇到了一些坑,下面简单的总结分享下

    非空校验
    知道自定义校验之前,需要知道基本的非空校验
    如下图,ElementUI已经帮助我们创建好了一个简单的demo,我们直接拿来用即可。

    2023022210551752.jpg

    2023022210551752.jpg


    这里我也是直接复制的demo,然后根据自己需求进行修改。

    2023022210551753.jpg

    2023022210551753.jpg


    简单的说下相关的一些地方吧
    一个表单包含着很多页面元素,根据自己的需求使用不同的组件去拼接即可:

    2023022210551854.jpg

    2023022210551854.jpg


    表单的元素我们可以直接在data生成一个表单数据,把里面的属性都放在数据里面,这样可以直接把这个表单传到后台进行交互。不然一个一个传也太麻烦了

    2023022210551855.jpg

    2023022210551855.jpg


    然后就是检验(rules),这里一般做对表单元素校验的处理
    除了手机号,密码,确认密码这三项,我都是只做了最基本的非空校验。

    2023022210551856.jpg

    2023022210551856.jpg


    我们可以注意到,每一个表单元素都有一个红色的星号,这就是必输项的一个标识,我们主要通过这个属性控制:
    required: true
    比如我现在把用户名的required: true去掉

    2023022210551857.jpg

    2023022210551857.jpg


    页面上的非空校验就没了,所以不论你校验写的再好,不加这个属性就等于没用。

    2023022210551958.jpg

    2023022210551958.jpg


    自定义校验
    我主要以两个较为经典的例子举例,一个是手机号的格式,一个是密码和确认密码的判断是否相同
    关于表单的自定义校验ElementUI也给了demo,就是我的第二个例子

    2023022210551959.jpg

    2023022210551959.jpg


    大家都知道,手机号都是有一定的规则的,不是只有11位数字就是这么简单的,还要以固定格式开头等。

    定义自定义校验函数
    针对这种格式,我们就可以使用自定义校验了,我们可以在data中定义自定义校验:

    2023022210551960.jpg

    2023022210551960.jpg


    可以理解成把它理解成一个变量,有着自定义的回调函数进行自定义错误提示
    可以看到首先是判断输入的手机号是否为空,如果为空给出的提示是:请输入手机号码
    如果输入的手机号不为空,那么就通过正则表达式判断是否合法,如果不合法的话,同样给出对应的提示信息,这便是自定义校验,根据自己的需求定义自己的规则。
    // 校验手机号是否合法
        var checkPhone = (rule, value, callback) => {
                    if (value === "") {
                            callback(new Error("请输入手机号码"))
                    } else if (!/^(13[0-9]|14[5|7]|15[0|1|2|3|4|5|6|7|8|9]|18[0|1|2|3|5|6|7|8|9])\d{8}$/.test(value)) {
                            callback(new Error("手机号格式有误,请输入正确的手机号码"))
                    } else {
                            callback()
                    }
            };

    使用自定义校验函数
    使用起来也很简单,在原有的表单校验基础上加上validator属性,值就是定义自定义函数的变量名
    注意:使用了自定义校验函数之后,就不要在这里写message提示信息了。直接在函数里面定义错误信息即可。

      phone: [ { required: true,validator: checkPhone, trigger: 'blur' }],
    两次密码是否相同这个demo直接拿着ElementUI给的demo即可。这里不再赘述

    总结
    通过表单自定义校验,大大提高了灵活性和可控性。个人还是比较喜欢的
    到此这篇关于Vue如何使用ElementUI对表单元素进行自定义校验及踩坑的文章就介绍到这了,更多相关Vue用ElementUI对表单自定义校验内容请搜索知鸟论坛以前的文章或继续浏览下面的相关文章希望大家以后多多支持知鸟论坛
  • 回复

    使用道具 举报

    发表于 2023-6-28 19:33:02 | 显示全部楼层
    风来时狂放 2023-6-28 19:33:02 看全部
    楼主,我太崇拜你了!我想我是一天也不能离开知鸟论坛
    回复

    使用道具 举报

    发表于 2023-6-28 20:40:36 | 显示全部楼层
    六翼天使494 2023-6-28 20:40:36 看全部
    我看不错噢 谢谢楼主!知鸟论坛越来越好!
    回复

    使用道具 举报

    发表于 2023-6-28 20:51:01 | 显示全部楼层
    永远爱你冰塘 2023-6-28 20:51:01 看全部
    楼主,我太崇拜你了!我想我是一天也不能离开知鸟论坛
    回复

    使用道具 举报

    发表于 2023-6-29 00:51:48 | 显示全部楼层
    塞翁364 2023-6-29 00:51:48 看全部
    楼主,我太崇拜你了!我想我是一天也不能离开知鸟论坛
    回复

    使用道具 举报

    发表于 2023-6-29 17:52:18 | 显示全部楼层
    尘埃416 2023-6-29 17:52:18 看全部
    既然你诚信诚意的推荐了,那我就勉为其难的看看吧!知鸟论坛不走平凡路。
    回复

    使用道具 举报

    发表于 2023-6-29 18:29:09 | 显示全部楼层
    丁侦球 2023-6-29 18:29:09 看全部
    楼主,大恩不言谢了!知鸟论坛是最棒的!
    回复

    使用道具 举报

    发表于 2023-6-30 00:09:28 | 显示全部楼层
    掌舵的鱼1987 2023-6-30 00:09:28 看全部
    楼主发贴辛苦了,谢谢楼主分享!我觉得知鸟论坛是注册对了!
    回复

    使用道具 举报

    发表于 2023-6-30 00:27:40 | 显示全部楼层
    普通人物怨 2023-6-30 00:27:40 看全部
    其实我一直觉得楼主的品味不错!呵呵!知鸟论坛太棒了!
    回复

    使用道具 举报

    发表于 2023-6-30 06:05:38 | 显示全部楼层
    当当当当裤裆坦 2023-6-30 06:05:38 看全部
    既然你诚信诚意的推荐了,那我就勉为其难的看看吧!知鸟论坛不走平凡路。
    回复

    使用道具 举报

    • 您可能感兴趣
    点击右侧快捷回复 【请勿灌水】
    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则 返回列表

    RSS订阅| SiteMap| 小黑屋| 知鸟论坛
    联系邮箱E-mail:zniao@foxmail.com
    快速回复 返回顶部 返回列表