jQuery Validation Engine验证控件调用外部函数验证的方法

2020-05-24 21:37:04易采站长站整理

<input type="radio" name="trial" class="m-radio col" id="nocheck"/>不通过
</div>
<div class="name-ipt"></div>
<div class="area-ipt add-td">
<div class="m-name"><span>备注:</span></div>
<textarea class="m-area add-tw validate[funcCall[yorn]]" id="remark" cols="30" rows="10"></textarea>
<span class="m-span add-stl">剩余可输入1000字</span>
</div>
</div>
</form>
<div class="add-sb">
<a href="#" class="save-btn m" ng-click="saveAudit()" >保存</a>
</div>
(有效:步骤1)

因为我是用的angular,所以给保存一个事件,在点击保存的时候触发事件,然后判断两个radio哪个被checked,其他的上面说过。接着触发验证进入自定义函数中。、、


//自己js文件中写
//保存
$scope.saveAudit = function(){
if($('#nocheck').attr('checked')){
$("#remark").attr("trialAttr",'N');
}else{
$("#remark").removeAttr('trialAttr');
}
if($('#approval').validationEngine('validate')){
//验证通过的话之后要执行的内容
}
}
(有效:步骤2)

自定义函数必须带rules.push(‘required’);同时return options.allrules.required.alertText;这个自定义函数写在自己的js文件里就行


//自己的js文件中写
function yorn(field, rules, i, options){
var trialAttr = field.attr("trialAttr") ;
var textareaval = field.val();

if(trialAttr == "N" && textareaval==''){
rules.push('required');
return options.allrules.required.alertText;
}
}
(有效:步骤3)

接下来要设置自定义提示信息了,找到jquery.validationEngine-zh_CN.js文件,然后在最下面自己跟随一个对象,函数名在前面,后面alertText后跟你要提示的信息。这样就OK了。

//这个在jquery.validationEngine-zh_CN.js中写

(有效:步骤4)

之前我在这个文件的下面按照api自定义了一个函数,但是发现根本无法执行,因为当进入验证的时候,首先判断validate[required,funcCall[yorn]]的自定义函数中是否存在required,如果不存在就无法进入到jquery.validationEngine-zh_CN.js这个文件中执行我们内部定义的函数。但是如果把自定义函数放在我们自己的js中,就会先执行我们自己js文件中的函数,最后才判断是否存在required,而这个时候我们已经push进去了,所以就不会报错说找不到你自定义函数名了。