javascript - 如何优雅的实现表单验证
黄舟
黄舟 2017-04-11 09:13:07
[JavaScript讨论组]

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

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;
}

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

黄舟
黄舟

人生最曼妙的风景,竟是内心的淡定与从容!

全部回复(5)
ringa_lee

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

PHP中文网

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

阿神

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

阿神
[
    { selector: '#type', msg: '请选择请假类别' },
    { selector: '#start_datetime_picker', msg: '请选择开始日期' }
    // ...
].some(function (item) {
    if ($(item.selector).val() == "") {
        $.toast(item.msg)
        return true;
    }
});

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

大家讲道理

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

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号