对象搜索算法挑战

写一个 function方法,它遍历一个对象数组(第一个参数)并返回一个包含相匹配的属性-值对(第二个参数)的所有对象的数组。如果返回的数组中包含 source 对象的属性-值对,那么此对象的每一个属性-值对都必须存在于 collection 的对象中。

例如,如果第一个参数是 [{ first: "Romeo", last: "Montague" }, { first: "Mercutio", last: null }, { first: "Tybalt", last: "Capulet" }],第二个参数是 { last: "Capulet" },那么你必须从数组(第一个参数)返回其中的第三个对象,因为它包含了作为第二个参数传递的属性-值对。

 

function where(collection, source) {
            let sourceArr = Object.keys(source);
            let arr = [];
            var keys = collection.map(item => {
                return Object.keys(item);
            });
            keys.map((item, index) => {
                for (let i = 0; i < sourceArr.length; i++) {
                    if (collection[index][sourceArr[i]] !== source[sourceArr[i]]) return;
                };
                arr.push(collection[index])
            });
            return arr;
        };

 

posted @ 2020-12-02 15:25  尘世英雄  阅读(85)  评论(0编辑  收藏  举报