• 技术文章 >web前端 >Bootstrap教程

    bootstrapValidator如何验证最大值和最小值限制

    青灯夜游青灯夜游2021-05-19 18:39:43转载397
    本篇文章给大家介绍一下bootstrapValidator验证最大值最小值范围限制的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。

    【相关推荐:《bootstrap教程》】

    录入该值的最大值与最小值 bootstrapValidator进行效验,使最小值不可大于最大值,最大值不可小于最小值

    刚开始的验证还是没事的,符合正常的验证规则

    在这里插入图片描述
    再把不符合规则的最大值改变,现在最小值已经比最大值小了,但是最大值没通过验证,说明在最小值框的内容改变时才会进行最小值的验证,最大值的框内容没改变,不会进行验证

    在这里插入图片描述

    一种办法是,在callback中加上该方法,对这个字段从新进行效验,但是两个需要校验的都需要加,就造成了无限循环,

    //从新验证该字段
    $('#form').data('bootstrapValidator').revalidateField('nMax');

    可以自己获取两个字段的值,手动进行比较,当符合验证规则,手动修改该字段的验证状态

    $('#form').data('bootstrapValidator').updateStatus("nMax", "VALID", null );

    两个值框进行对比

    	$("#form").bootstrapValidator({
    		message: 'This value is not valid',
    		feedbackIcons: {
    			valid: 'glyphicon glyphicon-ok',
    			invalid: 'glyphicon glyphicon-remove',
    			validating: 'glyphicon glyphicon-refresh'
    		},
    		
    		fields: {
    			nMin:{
    				validators:{
    					notEmpty:{
    						message:'最小值不能为空'
    					},
    					regexp: {
                            regexp: /^[0-9._]+$/,
                            message: '请输入有效的值'
                        },
    					callback: {
    						message: '最小值不可大于最大值',
    						callback: function(value, validator) {
    							if(value != ''){
    							 	var nMax = $("#form").data("bootstrapValidator").getFieldElements('nMax');
    								if(nMax.val()!='' && Number(nMax.val()) < Number(value)){
    									return false;
    								}else if(nMax.val()!='' && Number(nMax.val()) > Number(value)){
    									//从新验证该字段
    									//$('#form').data('bootstrapValidator').revalidateField('nMax');
    									 
    									//当符合规则手动修改该字段的验证状态
    									/* 因为上面方法两个字段相互验证 ,会造成死循环,所以在两个字段比较之后,并且符合验证规则,就手动修改该字段的验证状态 */
    									$('#form').data('bootstrapValidator').updateStatus("nMax", "VALID", null );
    									return true;
    								}else if(nMax.val()==''){
    									return true;
    								}else{
    									return true;
    								}
    							}else{
    							 	return true;
    							{
    							 
    						}
    					}
    				}
    			},
    			nMax:{
    				validators:{
    					notEmpty:{
    						message:'最大值不能为空'
    					},
    					regexp: {
                            regexp: /^[0-9._]+$/,
                            message: '请输入有效的值'
                        },
    					callback: {
    						message: '最大值不可小于最小值',
    						callback: function(value, validator) {
    							if(value != ''){
    							 	var nMin = $("#form").data("bootstrapValidator").getFieldElements('nMin');
    								if(nMin.val()!='' && Number(nMin.val())>Number(value)){
    									return false;
    								}else if(nMin.val()!='' && Number(nMin.val())<Number(value)){
    									//从新验证该字段
    									//$('#form').data('bootstrapValidator').revalidateField('nMin');
    									 
    									//当符合规则手动修改该字段的验证状态
    									/* 因为上面方法两个字段相互验证 ,会造成死循环,所以在两个字段比较之后,并且符合验证规则,就手动修改该字段的验证状态 */
    									$('#form').data('bootstrapValidator').updateStatus("nMin", "VALID", null );
    									return true;
    								}else if(nMin.val()==''){
    									return true;
    								}else{
    									return true;
    								}
    							}else{
    							 	return true;
    							}
    						}
    					}
    				}
    			}
    			
    		}	
    
    	});

    三个值进行比较

    nMin:{
    				validators:{
    					notEmpty:{
    						message:"最小值不能为空"
    					},
    					regexp: {
                            regexp: /^[0-9._]+$/,
                            message: '请输入有效的值'
                        },
    					callback: {
    						callback: function(value, validator) {
    							var nSetVal = $("#form").data("bootstrapValidator").getFieldElements('nSetVal');
    							var nMax = $("#form").data("bootstrapValidator").getFieldElements('nMax');
    							 
    							//最小值大于设定值
    							if( nSetVal.val()!='' && Number(nSetVal.val()) < Number(value) ){
    								 
    								return { message:'最小值不可大于设定值', flag:false };
    								
    							//最小值大于最大值
    							}else if( nMax.val()!='' && Number(nMax.val()) < Number(value) ){
    							
    								$('#form').data('bootstrapValidator').updateStatus("nSetVal", "VALID", null );
    								return { message:'最小值不可大于最大值', flag:false };
    								 
    							//最小值 小于 设定值
    							}else if( nSetVal.val()!='' && Number(nSetVal.val()) >= Number(value) ){
    								
    								if( Number(nMax.val()) < Number(value) ){
    									 
    									$('#form').data('bootstrapValidator').updateStatus("nMax", "VALID", null );
    									return { message:'最小值不可大于最大值', flag:false };
    								 
    								//最小值 小于设定值  小于最大值   符合全部要求
    								}else if( nMax.val()!='' && Number(nMax.val()) >= Number(value) && Number(nMax.val()) >= Number(nSetVal.val()) ){
    									 
    									$('#form').data('bootstrapValidator').updateStatus("nSetVal", "VALID", null );
    									$('#form').data('bootstrapValidator').updateStatus("nMax", "VALID", null );
    									return true;
    									 
    								//最小值 小于设定值  大于最大值 
    								}else{
    									return true;
    								}
    								 
    							}else{
    								return true;
    							}
    							 
    						}
    					}
    				}
    			},
    			nSetVal:{
    				validators:{
    					notEmpty:{
    						message:'设定值不能为空'
    					},
    					regexp: {
                            regexp: /^[0-9._]+$/,
                            message: '请输入有效的值'
                        },
    					callback: {
    						callback: function(value, validator) {
    							 
    							var nMin = $("#form").data("bootstrapValidator").getFieldElements('nMin');
    							var nMax = $("#form").data("bootstrapValidator").getFieldElements('nMax');
    							 
    							//设定值小于最小值
    							if( nMin.val()!='' && Number(nMin.val()) > Number(value) ){
    								 
    								return { message:'设定值不可小于最小值', flag:false };
    								
    							//设定值 大于 最大值
    							}else if( nMax.val()!='' && Number(nMax.val()) < Number(value) ){
    								 
    								$('#form').data('bootstrapValidator').updateStatus("nMin", "VALID", null );
    								return { message:'设定值不可大于最大值', flag:false };
    								 
    							//设定值 小于 最大值
    							}else if( nMax.val()!='' && Number(nMax.val()) >= Number(value) ){
    								 
    								 
    								if( nMin.val()!='' && Number(nMin.val()) > Number(value)){
    									 
    									$('#form').data('bootstrapValidator').updateStatus("nMax", "VALID", null );	
    									return { message:'设定值不可小于最小值', flag:false };
    									 
    								//设定值 大于最小值 小于最大值   符合全部要求
    								}else if( nMin.val()!='' && Number(nMin.val()) <= Number(value) && Number(nMax.val()) >= Number(value) ){
    									 
    									$('#form').data('bootstrapValidator').updateStatus("nMax", "VALID", null );
    									$('#form').data('bootstrapValidator').updateStatus("nMin", "VALID", null );
    									return true;
    									 
    								}else{
    									return true;
    								}
    								 
    							}else{
    								return true;
    							}
    						}
    					}
    				}
    			},
    			nMax:{
    				validators:{
    					notEmpty:{
    						message:"最大值不能为空"
    					},
    					regexp: {
                            regexp: /^[0-9._]+$/,
                            message: '请输入有效的值'
                        },
    					callback: {
    						callback: function(value, validator) {
    							var nMin = $("#form").data("bootstrapValidator").getFieldElements('nMin');
    							var nSetVal = $("#form").data("bootstrapValidator").getFieldElements('nSetVal');
    							 
    							//最小值大于最大值
    							if( nMin.val()!='' && Number(nMin.val()) > Number(value) ){
    								 
    								return { message:'最大值不可小于最小值', flag:false };
    								
    							//设定值 大于 最大值
    							}else if( nSetVal.val()!='' && Number(nSetVal.val()) > Number(value) ){
    								 
    								$('#form').data('bootstrapValidator').updateStatus("nMin", "VALID", null );
    								return { message:'最大值不可小于设定值', flag:false };
    								 
    							//最小值 小于 最大值
    							}else if( nMin.val()!='' && Number(nMin.val()) <= Number(value) ){
    									 
    								if(nSetVal.val()!='' && Number(nSetVal.val()) > Number(value)){
    									$('#form').data('bootstrapValidator').updateStatus("nMin", "VALID", null );
    									return { message:'最大值不可小于设定值', flag:false };
    									 
    								//最小值 小于最大值 设定值 小于最大值   符合全部要求
    								}else if( nSetVal.val()!='' && Number(nSetVal.val()) <= Number(value) && Number(nSetVal.val()) >= Number(nMin.val()) ){
    									 
    									$('#form').data('bootstrapValidator').updateStatus("nSetVal", "VALID", null );
    									$('#form').data('bootstrapValidator').updateStatus("nMin", "VALID", null );
    									return true;
    									 
    								//最小值 小于最大值 设定值 大于最大值
    								}else{
    									return true;
    								}
    								 
    							}else{
    								return true;
    							}
    						}
    					}
    				}
    			}

    bootstrapValidator 常用的验证

    //不为空验证
    notEmpty: {
         message: '必须输入或者必须选择'
    }
    
    //正整数验证
    digits : {
        message : '字段必须是正整数'
    }
    
    //内容最小值验证
    greaterThan: {
        value : 1,
        message : '最小输入1'
    }
    
    //内容最大值验证
    lessThan: {
        value : 100
        message : '最大输入100'
    }
    
    //正则验证
    regexp: {
        regexp: /^[a-zA-Z0-9_]+$/,
        message: '正则验证,这里验证只能输入大小写字母数字和下划线'
    }
    
    //内容长度验证
    stringLength : {
        min : 2,
        max : 25,
        message : '长度2-25位字符'
    }
    
    //回调验证
    callback: {
        message: '请输入整数',
    	callback: function(value, validator) {	
    			//可以return   true  /  false
    			//return  false;
    			//也可以这样
    			return { message:'最小值不可大于最大值', flag:false };
    	}
    }
    
    //日期验证
    date: {
      	format: 'YYYY/MM/DD',
        message: '日期无效'
    }
    
    //数字验证
    digits: {
        message: '该值只能包含数字。'
    }
    
    //ajax验证
    threshold :  6 , //有6字符以上才发送ajax请求,(input中输入一个字符,插件会向服务器发送一次,设置限制,6字符以上才开始)
    remote: {//ajax验证。server result:{"valid",true or false} 向服务发送当前input name值,获得一个json数据。例表示正确:{"valid",true}  
        url: 'exist2.do',//验证地址
        message: '用户已存在',//提示消息
        delay :  2000,//每输入一个字符,就发ajax请求,服务器压力还是太大,设置2秒发送一次ajax(默认输入一个字符,提交一次,服务器压力太大)
        type: 'POST'//请求方式
     }
     
    //复选框验证
    choice: {
      	min: 2,
        max: 4,
        message: '请选择2-4项'
    }
    
    //密码确认
    identical: {
    	field: 'confirmPassword',
        message: 'The password and its confirm are not the same'
    }

    更多编程相关知识,请访问:编程视频!!

    以上就是bootstrapValidator如何验证最大值和最小值限制的详细内容,更多请关注php中文网其它相关文章!

    声明:本文转载于:csdn,如有侵犯,请联系admin@php.cn删除
    上一篇:浅谈Bootstrap3和Bootstrap4的差异 下一篇:浅谈bootstrapTable如何动态设置行和列的颜色
    大前端线上培训班

    相关文章推荐

    • 深入浅析Bootstrap中的自动定位浮标• 浅谈查看bootstrap和jQuery版本对应关系的方法• 3 分钟使用Bootstrap-Table实现满意的表格功能• bootstrapTable如何重新加载数据?3种方式了解一下!• 浅谈css grid比Bootstrap更适合创建布局的原因

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网