【发布时间】:2010-04-23 13:17:33
【问题描述】:
我正在尝试熟悉 jQuery 验证自定义方法,但似乎有点困惑。为什么我的自定义方法中的 this.optional(element) 总是返回 false?
这是我的代码示例:
<script type="text/javascript">
$(document).ready(function(){
$.validator.addMethod('customemethod', function(val, el){
return this.optional(el) || false;
}, 'custom method says its INVALID !');
$('#myform').validate({ignore: '*[ignore]'});
$('#validate').click(function(){
$('#result').text($('#myform').validate().form());
return false;
});
});
</script>
<form id="myform">
<div><input type="text" id="customfield" name="customfield" /></div>
<script type="text/javascript">
$(document).ready(function(){$('#customfield').rules('add', { required: true, customemethod: true } ) } );
</script>
<div><input type="text" id="customfield2" name="customfield2" /></div>
<script type="text/javascript">
$(document).ready(function(){$('#customfield2').rules('add', { required: false, customemethod: true } ) } );
</script>
<div id="result"></div>
<input id="validate" type="submit" />
</form>
如果元素不是必需的并且它的值不为空 - 调用验证方法并且在这种情况下我需要返回 true。 但是 this.optional(el) 总是假的 :(
我该如何解决?如何检查自定义方法中是否需要元素? 谢谢。
【问题讨论】: