2

我的数组有字符串值:

var bannedWords = ["cat","dog","test"]

我的文本输入字段检查值是否包含数组中的单词:

var title = $j('#edit-content').val()
if ($j.inArray(title, bannedWords) != -1) { alert("it's inside the array") }

当值为“cat”时,它按预期工作。当值为“猫是黑色的”时,我想要警报,因为“猫”在输入值内。

我明白为什么它不起作用,但我不知道我该怎么做?值中有某种循环?

提前致谢!

4

4 回答 4

3

您可以从数组中构建一个正则表达式并使用它来测试输入:

// The 'i' flag matches values regardless of case.
var regex = new RegExp('\\b' + bannedWords.join("\\b|\\b") + '\\b', 'i');

// Regex would equal /\bcat\b|\bdog\b|\btest\b/i
var valid = !regex.test($("#edit-content").val());

示例:http: //jsfiddle.net/aZbWP/1

于 2013-01-09T17:24:52.280 回答
2

您需要将值拆分为一个数组并单独测试每个单词:

var words = $j('#edit-content').val().split(' ');
$.each(words, function(index, word) {
    if ($j.inArray(word, bannedWords) != -1) { 
        alert('it\'s inside the array') 
    }
});

示例小提琴

于 2013-01-09T17:18:57.287 回答
1

您可以使用循环来检查:

function in_string(words, string) {
    for (var i = 0; i < words.length; i++) {
        if (string.indexOf(words[i]) !== -1) {
            return true;
        }
    }

    return false;
}

var valid = in_string(bannedWords, $j('#edit-content').val())

尽管我建议您在服务器端执行此操作。手动提交请求并绕过您的 JS 验证并不难。

于 2013-01-09T17:19:11.233 回答
0

在bannedWords 数组中使用正则表达式会更强大(例如,您可以一次性检查“cat”、“Cat”和“CAT”)并使您能够更简洁地做您想做的事情。

例如:http: //jsfiddle.net/PS9FG/1

您需要稍微修改此代码以适合您自己的代码(例如,您拥有的 jQuery 行)。

var bannedWords = [
  /cat/i,    // the i after each expression means case-insensitive
  /dog/i,
  /test/i
];


document.getElementById('checkBtn').onclick = function() {
    var bWrd = bannedWords.length;
    while (bWrd) {    // loop through each pattern in the array
        bWrd -= 1;
        if (document.getElementById('edit-content').value.match(bannedWords[bWrd])) {
            alert("it's inside the array");
        }
    }
};

但希望这能让您了解它是如何工作的。

于 2013-01-09T17:32:28.477 回答