1

我有一个问题要问你,我自己似乎无法弄清楚。
假设我想验证用户的名字。有些可以包含多个部分,例如“John William”,中间有一个空格。我想要做的是将输入匹配到一个正则表达式,该表达式找出名称是否在开头或结尾包含任何空格。
此外,正则表达式应该检查名称中是否只有字母(az,小写和大写)。

到目前为止,这是我想出的:

/^\s+[A-z]+|[A-z]+\s+$/

但不知何故,这个正则表达式不会注意到任何其他字符(如破折号、下划线、& 符号等)。基本上它所做的只是告诉我输入的开头或结尾是否有空格。

有谁可以帮我离开这里吗?

编辑:

这是我正在使用的完整代码:

$(document).ready(function() {
    $('#firstname, #lastname').bind('keyup blur', function() {
        var _input = $(this);
        var _illegal = Validate_Regexp(_input.val(), /^\s+[A-Za-z]+|[A-Za-z]+\s+$/);
        if (_illegal == true) {
            $("#"+_input.attr('id')+".validator").css({
                'background-image' : 'url(./images/icons/bullet_red.png)',
            });
        } else {
            $("#"+_input.attr('id')+".validator").css({
                'background-image' : 'url(./images/icons/bullet_green.png)',
            });
        }
    });
});

function Validate_Regexp($value, $regexp) {
    return $regexp.test($value);
}

编辑2:

我同意查理的回答,但是他的回答迫使我有两个部分的名字,而不是我想要的。
我将代码更改为:

var isLegal = /^[a-zA-Z]+(\s+[a-zA-Z]+)?$/.test(stringToTest);

到:

var isLegal = /^[a-zA-Z]+(\s[a-zA-Z]+)*?$/.test(stringToTest);
4

2 回答 2

2

我注意到您正在检查非法的字符串。让我们把它转过来检查一个有效的字符串:

 var isValid = /^[a-zA-Z]+(\s+[a-zA-Z]+)?$/.test(stringToTest);

结果:

 /^[a-zA-Z]+(\s+[a-zA-Z]+)?$/.test("john doe"); // true
 /^[a-zA-Z]+(\s+[a-zA-Z]+)?$/.test("john"); // true

 /^[a-zA-Z]+(\s+[a-zA-Z]+)?$/.test("john d_oe"); // false
 /^[a-zA-Z]+(\s+[a-zA-Z]+)?$/.test(" john doe "); // false
 /^[a-zA-Z]+(\s+[a-zA-Z]+)?$/.test(" john doe"); // false
 /^[a-zA-Z]+(\s+[a-zA-Z]+)?$/.test("john doe "); // false
 /^[a-zA-Z]+(\s+[a-zA-Z]+)?$/.test("john "); // false

翻译成您现有的代码:

    var isValid = Validate_Regexp(_input.val(), /^[a-zA-Z]+(\s+[a-zA-Z]+)?$/);
    if (isValid) {
        $("#"+_input.attr('id')+".validator").css({
            'background-image' : 'url(./images/icons/bullet_blue.png)',
        });
    } else {
        $("#"+_input.attr('id')+".validator").css({
            'background-image' : 'url(./images/icons/bullet_red.png)',
        });
    }
于 2012-07-29T23:52:52.400 回答
0

您真的不在乎是否有前导或尾随空格,或者名称之间有多少,所有这些东西都很容易管理而不会打扰用户。

所以一个合适的功能可能是:

function checkNames(s) {
  // Remove excess spaces
  s.replace(/(^\s*)|(\s*$)/g, '').replace(/\s+/g, ' ');

  // Check remaining content
  return /[a-z]+ [a-z]+/i.test(s);
}

但请注意,名称可以连字符并包含数字(例如 William Gates the 3rd)或英文字母以外的字母。所以通常你让用户输入他们想要的任何东西,只处理空格。

于 2012-07-30T02:57:54.480 回答