6

我想针对 20 个左右的正则表达式测试给定的字符串。在 Javascript 中执行此操作的干净方法是什么?我更关心干净的代码和可读性而不是效率(但我也不希望它超级慢)。

现在我有:

if (href.indexOf('apple.com') > -1 ||
    href.indexOf('google.com') > -1 ||
    href.indexOf('yahoo.com') > -1 ||
    href.indexOf('facebook.com') > -1) {
    performDarkMagic()
}

但随着该列表的增长,它会开始看起来有点混乱。也许我可以创建一个正则表达式数组并执行 _.any() 之类的东西并在每个上应用 regex.test ?

编辑:要匹配的字符串/正则表达式可能会变得更加复杂,我只是使用简单的 URL 来使示例可读。

4

6 回答 6

8

对正则表达式使用测试函数。

更多关于正则表达式的信息在这里。 https://developer.mozilla.org/en/JavaScript/Reference/Global_Objects/RegExp

var re = /((google)|(facebook)|(yahoo)|(apple))\.com/;
re.test( str ); // returns true or false;

测试用例。

现场演示:http: //jsfiddle.net/rkzXP/1/

    var func = function( str ){
        var re = /((google)|(facebook)|(yahoo)|(apple))\.com/;
        return re.test( str );
    };
    test("test for valid values", function() {
        equal( func("google.com"), true);
        equal( func("facebook.com"), true);
        equal( func("apple.com"), true);
    });
    test("test for invalid values", function() {
        equal( func("googl.com"), false);
        equal( func("faceook.com"), false);
        equal( func("apple"), false);
    });

所以你可以重写你的代码如下。

var re = /((google)|(facebook)|(yahoo)|(apple))\.com/;
if( re.test(str) ){
    performDarkMagic()
}
于 2012-06-06T20:05:31.227 回答
4
var patterns = ['apple.com', 'google.com', 'yahoo.com', 'facebook.com', ...]
var callFunc = false;

patterns.forEach(function(item){
   if(href.indexOf(item) > -1){
       callFunc = true;
       break;
   }
});

if(callFunc) {
   performDarkMagic();
}
于 2012-06-06T20:06:31.717 回答
4

是的,构建一个数组并使用.any()or.some()就可以了,尤其是当值超过 4 个时:

if (["apple","google","yahoo","facebook"].some(host => href.includes(`${host}.com`)) {
    performLightMagic();
}

但是我在那里看不到正则表达式,只有字符串;所以你可以简化使用regex.test()

if (/apple\.com|google\.com|yahoo\.com|facebook\.com/.test(href)) { performLightMagic(); }

甚至

if (/(apple|google|yahoo|facebook)\.com/.test(href)) { performLightMagic(); }
于 2012-06-06T20:07:18.897 回答
2

您可以将每个放入数组中,然后循环遍历每个。

于 2012-06-06T20:03:51.180 回答
-1

我会怎么做:把它分解成一个函数。将每个正则表达式放在一个数组中,循环它们并在第一次 indexOf > -1 时返回 true。如果到达循环的末尾,则返回 false。

于 2012-06-06T20:04:58.283 回答
-2

遍历一个正则表达式数组,然后执行:

result=result AND (result_of_regex);

next;

循环返回结果后

于 2012-06-06T20:06:20.680 回答