zoukankan      html  css  js  c++  java
  • 对象搜索算法挑战

    写一个 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;
            };
  • 相关阅读:
    简单的逻辑学 笔记
    中国古代文化常识 笔记
    Docker 使用官方镜像
    Docker 入门 之基本命令
    Windows.form增删改查
    自定义控件
    LISTVIEW
    窗体布局
    计算器
    登录
  • 原文地址:https://www.cnblogs.com/swordLaughsHeaven/p/14074032.html
Copyright © 2011-2022 走看看