jQuery验证插件:只接受字母字符?

时间:2010-05-08 13:05:38

标签: jquery validation jquery-validate

我想使用jQuery的验证插件来验证只接受字母字符的字段,但似乎没有为它定义规则。我搜索过Google,但我发现没什么用处。

有什么想法吗?

感谢您的帮助。

6 个答案:

答案 0 :(得分:79)

如果您包含其他方法文件,则这是1.7的当前文件:http://ajax.microsoft.com/ajax/jquery.validate/1.7/additional-methods.js

您可以使用lettersonly规则:)其他方法是您下载的zip的一部分,您随时可以找到最新的here

以下是一个例子:

$("form").validate({
  rules: {
    myField: { lettersonly: true }
  }
});

值得注意的是,每个附加方法都是独立的,您可以包含该特定方法,只需将其放在.validate()来电之前:

jQuery.validator.addMethod("lettersonly", function(value, element) {
  return this.optional(element) || /^[a-z]+$/i.test(value);
}, "Letters only please"); 

答案 1 :(得分:14)

小心,

jQuery.validator.addMethod("lettersonly", function(value, element) 
{
return this.optional(element) || /^[a-z," "]+$/i.test(value);
}, "Letters and spaces only please"); 

[a-z," "]通过添加逗号和引号,您可以在输入框中添加空格,逗号和引号。

对于空格+文本,只需执行以下操作:

jQuery.validator.addMethod("lettersonly", function(value, element) 
{
return this.optional(element) || /^[a-z ]+$/i.test(value);
}, "Letters and spaces only please");

[a-z]这允许空格以及仅文本。

............................................... .............................

也是消息"信件和空格只请"如果消息中已有消息,则不需要:

messages:{
        firstname:{
        required: "Enter your first name",
        minlength: jQuery.format("Enter at least (2) characters"),
        maxlength:jQuery.format("First name too long more than (80) characters"),
        lettersonly:jQuery.format("letters only mate")
        },

亚当

答案 2 :(得分:4)

只是尼克回答的一小部分(效果很好!):

例如,如果要在字母之间留出空格, 你可以限制只输入全名的字母,但它也应该允许空格 - 只需用逗号列出下面的空格。如果您需要允许任何其他特定字符,也可以采用相同的方式:

jQuery.validator.addMethod("lettersonly", function(value, element) 
{
return this.optional(element) || /^[a-z," "]+$/i.test(value);
}, "Letters and spaces only please");       

答案 3 :(得分:2)

Nick和Adam的答案都非常有效。

如果您想要允许拉丁字符(例如áç),我想添加备注:

jQuery.validator.addMethod('lettersonly', function(value, element) {
    return this.optional(element) || /^[a-z áãâäàéêëèíîïìóõôöòúûüùçñ]+$/i.test(value);
}, "Letters and spaces only please");

答案 4 :(得分:1)

允许字母和空格

jQuery.validator.addMethod("lettersonly", function(value, element) {
return this.optional(element) || /^[a-z\s]+$/i.test(value);
}, "Only alphabetical characters");

$('#yourform').validate({
        rules: {
            name_field: {
                lettersonly: true
            }
        }
    });

答案 5 :(得分:0)

 $('.AlphabetsOnly').keypress(function (e) {
        var regex = new RegExp(/^[a-zA-Z\s]+$/);
        var str = String.fromCharCode(!e.charCode ? e.which : e.charCode);
        if (regex.test(str)) {
            return true;
        }
        else {
            e.preventDefault();
            return false;
        }
    });