Javascript正则表达式空间检查

Javascript regular expression spaces check

本文关键字:检查 空间 正则表达式 Javascript      更新时间:2024-04-12

我有一个问题要问你,我自己似乎无法解决
假设我想验证一个用户的名字。有些可以包含多个部分,比如"约翰·威廉",中间有一个空格。我想做的是将输入匹配到一个正则表达式,该表达式查找名称的开头或结尾是否包含空格
此外,正则表达式应该检查名称中是否只有字母(a-z,大小写都有)。

这就是我到目前为止想到的:

/^'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);

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

 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)',
        });
    }

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

因此,一个合适的函数可能是:

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)或英文字母表以外的字母。所以,通常你让用户键入他们想要的任何内容,只需处理空格。