使用 indexOf 匹配精确数组元素(正则表达式 - 边界匹配数组)
Matching exact array elements with indexOf (regex - boundary match arrays)
我遇到了匹配数组和字符串的问题,但正常的正则表达式方法(边界匹配)似乎对我的情况不起作用。
我需要使用不同的单词边界吗?或者有人有更简洁的解决方案吗?
var nameArray = ['AA', 'BB', 'WBB'];
var idArray = ['AA','BB','CC'];
var counter=0;
for(var j=0; j<idArray.length;j++)
{
for(var i=0; i<nameArray.length;i++)
{
if(nameArray[i].indexOf(idArray[j]) != -1)
counter++;
/*
if(nameArray[i].indexOf('/\b'+idArray[j]+'\b/') != -1)
counter++;
*/
/*
if('/\b'+nameArray[i]+'\b/'.indexOf(idArray[j]) != -1)
counter++;
*/
}
}
console.log(counter);
如您所见,检测到 3 个匹配项,但我需要它来仅识别整个单词匹配项(在本例中为 2 个)。
循环和结构是必需的,因为我需要在我的项目中处理大型数组。
JSFiddle:Link
var nameArray = ['AA', 'BB', 'WBB'];
var idArray = ['AA','BB','CC'];
const match = (source, target) => source.filter(value => target.includes(value)).length
console.log(match(nameArray, idArray))
只需将 indexOf 更改为 ==
var nameArray = ['AA', 'BB', 'WBB'];
var idArray = ['AA', 'BB', 'CC'];
var counter = 0;
for (var j = 0; j < idArray.length; j++) {
for (var i = 0; i < nameArray.length; i++) {
if (nameArray[j] == idArray[i])
counter++;
}
}
console.log(counter);
我遇到了匹配数组和字符串的问题,但正常的正则表达式方法(边界匹配)似乎对我的情况不起作用。
我需要使用不同的单词边界吗?或者有人有更简洁的解决方案吗?
var nameArray = ['AA', 'BB', 'WBB'];
var idArray = ['AA','BB','CC'];
var counter=0;
for(var j=0; j<idArray.length;j++)
{
for(var i=0; i<nameArray.length;i++)
{
if(nameArray[i].indexOf(idArray[j]) != -1)
counter++;
/*
if(nameArray[i].indexOf('/\b'+idArray[j]+'\b/') != -1)
counter++;
*/
/*
if('/\b'+nameArray[i]+'\b/'.indexOf(idArray[j]) != -1)
counter++;
*/
}
}
console.log(counter);
如您所见,检测到 3 个匹配项,但我需要它来仅识别整个单词匹配项(在本例中为 2 个)。
循环和结构是必需的,因为我需要在我的项目中处理大型数组。
JSFiddle:Link
var nameArray = ['AA', 'BB', 'WBB'];
var idArray = ['AA','BB','CC'];
const match = (source, target) => source.filter(value => target.includes(value)).length
console.log(match(nameArray, idArray))
只需将 indexOf 更改为 ==
var nameArray = ['AA', 'BB', 'WBB'];
var idArray = ['AA', 'BB', 'CC'];
var counter = 0;
for (var j = 0; j < idArray.length; j++) {
for (var i = 0; i < nameArray.length; i++) {
if (nameArray[j] == idArray[i])
counter++;
}
}
console.log(counter);