我在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()无法找到深层嵌套的属性。
如果函数可以支持复杂的对象作为源,而不仅仅是数组,那将是非常酷的。
感谢您的帮助,谢谢。
答案 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"]));