如何检查数组是否具有定义值为

时间:2017-09-14 14:09:47

标签: javascript knockout.js lodash

我在javascript中有一系列复杂的对象和数组,例如:

var array = [
    { "simpleProp": "some value" },
    { "booleanProp": false },
    {
        "arrayProp": [
            { "prop1": "value1" },
            {
                "prop2": {
                    "prop22": "value22",
                    "prop23": "value23"
                } 
            },
            { "prop3": "value3" },
            { "booleanProp": true }
        ]
    }
];

我必须知道我的数组中是否存在具有已定义值的属性,例如:

   function some(array, property, value) {
        //some logic here
       // return boolean
    };

也就是说,对于我的源数组,结果如下:

var result = some(array,“booleanProp”,true)    - 必须为TRUE。

我尝试使用lodash函数_.some(),但它为我的数组返回false,它出现_.some()无法找到深层嵌套的属性。

如果函数可以支持复杂的对象作为源,而不仅仅是数组,那将是非常酷的。

感谢您的帮助,谢谢。

2 个答案:

答案 0 :(得分:3)

您可以通过检查实际对象来使用迭代和递归方法,如果值是对象,则迭代对象的键。

function some(object, property, value) {
    return object[property] === value || Object.keys(object).some(function (k) {
         return object[k] && typeof object[k] === 'object' && some(object[k], property, value);
    });
}

var data = [{ simpleProp: "some value" }, { booleanProp: false }, { arrayProp: [{ prop1: "value1" }, { prop2: { prop22: "value22", prop23: "value23" } }, { prop3: "value3" }, { booleanProp: true }] }];

console.log(some(data, 'booleanProp', true)); // true
console.log(some(data, 'foo', 42));           // false

答案 1 :(得分:0)

以上解决方案很棒,但不适用于Array。 因此,我对其进行了一些修改,现在它可以同时用于数组和常规属性。甚至In Arrays元素的位置也可以是任何东西。

const data = {
    "names": [
      {
        "name": {
          'homename': 'Raju',
          'academisName': 'Rajpal',
          'callingName': ['Raj', 'Rajpal', 'Raju']
        },
        "defaultName": "Raj"
      }]
  }

数组代码:

const some = (object, property, value) => {
  return _.isArray(value) && _.isEqual(_.sortBy(object[property]), _.sortBy(value)) || object[property] === value || Object.keys(object).some(function (k) {
    return object[k] && typeof object[k] === 'object' && some(object[k], property, value);
  });
}

const data = {
  "names": [{
    "name": {
      'homename': 'Raju',
      'academisName': 'Rajpal',
      'callingName': ['Raj', 'Rajpal', 'Raju']
    },
    "defaultName": "Raj"
  }]
}
const some = (object, property, value) => {
  return _.isArray(value) && _.isEqual(_.sortBy(object[property]), _.sortBy(value)) || object[property] === value || Object.keys(object).some(function(k) {
    return object[k] && typeof object[k] === 'object' && some(object[k], property, value);
  });
}
console.log('Result 1', some(data, 'callingName', ["Raj", "Rajpal", "Raju"]));
console.log('Result 2', some(data, 'callingName', ["Rajpal", "Raj", "Raju"]));
<script src="https://cdn.jsdelivr.net/npm/lodash@4.17.15/lodash.js"></script>

注意value.sort()将使数组发生变化,因此我使用了_.sortBy(value),与object[property]相同

 console.log(some(data, 'callingName',  ["Raj", "Rajpal", "Raju"]));
 console.log(some(data, 'callingName', ["Rajpal", "Raj", "Raju"]));