所以我尝试在线查看几个解决方案,但我找不到解决方案来解决使用bootstrapvalidator启用和禁用字段验证的问题。
当有人输入负数(例如-4,-100,-545等)和任何非数字的数字(例如4.4.4,4.r,4t)时,我有一个字段应该给出错误等等)。但是,当用户输入-999时,我想提出一个不会出错的条件。
当用户输入非负数和数字数字的其他数字时,代码运行良好。如果用户输入负数或非数字数字,则会显示错误。当用户输入-999时验证为true(不显示错误),但如果用户将数字(-999)更改为其他数字(如负数和非数字数),我的字段验证将停止工作(意味着不要显示任何错误,虽然它应该显示)。
那么如何启用和禁用字段验证或设置字段验证条件以使用bootstrapValidator来解决我的问题.. ???
希望你们已经遇到过这样的问题,我希望你能帮我解决这个难题。
您可以在此处尝试:https://jsfiddle.net/os3b0dqx/了解其工作原理
我的template.html看起来像:
<form class="well form-horizontal" action=" " method="post" id="myform">
<div class="form-group">
<label class="col-xs-3 control-label">Length</label>
<div class="col-xs-5">
<input type="text" class="form-control" id="length" name="length" />
</div>
</div>
<div class="form-group">
<div class="col-xs-5 col-xs-offset-1">
<button type="submit" class="btn btn-default">Submit</button>
</div>
</div>
</form>
<script>
$(document).ready(function() {
$('#myform').bootstrapValidator({
feedbackIcons: {
validating: 'glyphicon glyphicon-refresh'
},
fields: {
length: {
validators: {
greaterThan: {
value: 0,
message: 'The value must be greater than or equal to zero'
},
numeric: {
message: 'The value is not a number',
thousandsSeparator: '',
decimalSeparator: '.'
},
notEmpty: {
message: 'Please fill the length'
}
}
},
}
}).on('click keyup input change', '[name="length"]', function() {
if ($(this).val() == -999) {
$('#myform').bootstrapValidator('enableFieldValidators', 'length', false);
} else {
$('#myform').bootstrapValidator('validateField', 'length');
//$('#myform').bootstrapValidator('enableFieldValidators','length',true);
// both "validateField" and "enableFieldValidators" doesn't work for me..
}
});
});
答案 0 :(得分:0)
删除您的事件侦听器,并使用只允许正数和特定值的正则表达式替换前两个规则:
$('#myform').bootstrapValidator({
fields: {
length: {
validators: {
regexp: {
regexp: '^[+]?[0-9]+([.,][0-9]+){0,1}$|^-999$',
message: 'The value must be a number greater than or equal to zero'
},
notEmpty: {
message: 'Please fill the length'
}
}
},
}
});