jQuery验证少于 [英] jQuery validate less than

查看:91
本文介绍了jQuery验证少于的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在尝试为jQuery编写小于"验证器.我想将一个文本框与另一个文本框进行比较,所以如果有:

I am trying to write a "Less than" validator for jQuery. I want to compare one text box against another, so if I have:

<input type="text" id="value1" /> <input type="text" id="value2" />

我希望我的验证器看起来像

I want my validator to look like

$('#myForm').validate({rules: { value1: { lessThan: "#value2" } } });

我已经尝试过了,但是无法正常工作:

I have tried this but I can't get it to work:

$.validator.addMethod('lessThan', function(value, element, param) {
    var i = parseInt(value);
    var j = parseInt($(param).val());
    return i >= j;
}, "Less Than");

另一个问题是我应该将该代码放在哪里?是在$(document).ready中还是仅在标记中?

Another question is where should I put that code? In $(document).ready or just in a tag?

推荐答案

我是个白痴.我在实际代码中做了一些错别字,弄乱了我在许多验证器方法中看到的this.optional(element).这是工作功能:

I'm an idiot. I had made some typo's in my actual code and I'd messed up the this.optional(element) that I see in a lot of validator methods. Here is the working function:

$.validator.addMethod('lessThanEqual', function(value, element, param) {
    if (this.optional(element)) return true;
    var i = parseInt(value);
    var j = parseInt($(param).val());
    return i <= j;
}, "The value {0} must be less than {1}");

这是精简版

$.validator.addMethod('lessThanEqual', function(value, element, param) {
    return this.optional(element) || parseInt(value) <= parseInt($(param).val());
}, "The value {0} must be less than {1}");

现在,我需要弄清楚在更改field2时如何重新运行字段1的验证.

Now I need to figure out how to rerun validation for field 1 when I change field2.

这篇关于jQuery验证少于的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆