微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

javascript – .filter()数组使用另一个数组的元素

我有一系列人的名字以及他们的语言知识.我想要做的是将过滤器传递到语言列并过滤掉任何不匹配的结果.

这是示例数组

var myArray = [["Steppen","Spanish Polish"],["Wolf","Spanish Polish Tagalog"],["Amanda","Spanish"],["Ada","Polish"],["Rhonda","Spanish Tagalog"]];

传入过滤器,它可以是一种语言,也可以是多种语言.即使过滤器中的一种语言匹配 – 也应该返回结果.因此,例如,“塔加拉族语”的过滤器应该返回 – Wolf和Rhonda. “西班牙语波兰语”的过滤器应该归还给所有人 – 西班牙语或波兰语的匹配.

我写了过滤器功能,但由于某种原因它被卡住了,当我通过过滤器“Tagalog”它只迭代到阵列中的第二个单元格(西班牙语波兰语塔加拉族语)并重复多次而不是前进.

我做错了什么,我应该以不同的方式迭代吗?

var userPassedFilter = new Array();
 userPassedFilter[0] = "Tagalog";

 newArray = consolidatedFilters(myArray,userPassedFilter);
 console.log(newArray);

 function consolidatedFilters(passedArray,passedFilter)
 {
 var filteredArray = passedArray.filter(    
    function(el)
    {
        for (var i = 0; i < passedArray.length; i++)
         {
            console.log("i is " + i);
             for (var j in passedFilter)
            {
                console.log("Passed Filter j " + passedFilter[j]);
                console.log("Passed Array  i " + passedArray[i][1]);        
                console.log("String Search " + passedArray[i][1].search(passedFilter[j]));

                if (passedArray[i][1].search(passedFilter[j]) != -1)
                {
                    return true;
                }
            }           
        }
         return false;
    }
 );     
 return filteredArray;
 }

解决方法

对我而言,似乎你让它变得有点过于复杂.

>迭代三次(过滤,循环,循环).
>为数组使用for in循环.
>同时使用新阵列和[…].

我稍微更新了一下,看起来这就是你想要的:http://jsfiddle.net/pimvdb/RQ6an/.

var myArray = [["Steppen","Spanish Tagalog"]];

var userPassedFilter = ["Tagalog"];

newArray = consolidatedFilters(myArray,userPassedFilter);
console.log(newArray);

function consolidatedFilters(passedArray,passedFilter) {
    var filteredArray = passedArray.filter(
    function(el) { // executed for each person
        for (var i = 0; i < passedFilter.length; i++) { // iterate over filter
            if (el[1].indexOf(passedFilter[i]) != -1) {
                return true; // if this person kNows this language
            }
        }
        return false;
    }
    );     
    return filteredArray;
}

原文地址:https://www.jb51.cc/js/155879.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐