如何优雅的实现表单验证

发布于 2022-09-02 13:20:36 字数 433 浏览 17 评论 0

平时写表单验证时一般都是这样写的:

if($('#type').val() == ""){
    $.toast("请选择请假类别");
    return false;
}
if($('#start_datetime_picker').val() == ""){
    $.toast("请选择开始日期");
    return false;
}
if($('#end_datetime_picker').val() == ""){
    $.toast("请选择结束日期");
    return false;
}
if($('#reason').val() == ""){
    $.toast("请选择原因");
    return false;
}

这样写太痛苦了。所以请教大家,有什么更好的写法呢?或者说如何封装一下呢?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(5

波浪屿的海角声 2022-09-09 13:20:36

表单验证比较好的实践方式是将每类验证都封装为一个验证策略,如非空验证,数字验证,正则验证等,然后将表单项传入对应策略得到验证结果。

つ可否回来 2022-09-09 13:20:36
[
    { selector: '#type', msg: '请选择请假类别' },
    { selector: '#start_datetime_picker', msg: '请选择开始日期' }
    // ...
].some(function (item) {
    if ($(item.selector).val() == "") {
        $.toast(item.msg)
        return true;
    }
});

不想加第三方库就这么写,不然还是看看jQuery Validate

明媚殇 2022-09-09 13:20:36

参考下这个
jQuery Validate | 菜鸟教程
http://www.runoob.com/jquery/jquery-plug...

友欢 2022-09-09 13:20:36

如何JS技术不错,可以尝试自己封装,你把你写的函数绑给form,然后遍历每个子节点(input),然后根据节点上面你自定义的元素如data-type="number",然后自行对应你写的方法函数。话说最近在封装,当水平有限,写的各种BUG。 所以打算借助第三方插件了,如:jQuery Validate

夜司空 2022-09-09 13:20:36

你可以看看这个:https://github.com/WLDragon/sm-validator
直接把正则写在html上就可以了,很方便的,看看demo你就明白
https://wldragon.github.io/sm-validator/

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文