|
|
5
garyvh2
6 年前
根据需要,有多种方法。
脏支票
对于脏检查对象在两个数组上具有相同内存引用的位置,可以执行以下操作。
var firstPerson = {
name: 'Peter',
location: 'florida'
}
var secondPerson = {
name: 'Robert',
location: 'California'
}
var allowed = [secondPerson];
var check = [firstPerson, secondPerson];
var result = check.filter(item => allowed.includes(item));
console.log(result);
特定属性检查
对于特定的属性检查,可以使用
find
并比较
check
和
allowed
,属性如下
name
或
location
var check = [
{
name: 'Peter',
location: 'florida'
},
{
name: 'Robert',
location: 'California'
}
];
var allowed = [
{
name: 'Robert',
location: 'Boston'
}
];
var result = check.filter(checkPerson => allowed.find(allowPerson => allowPerson.name === checkPerson.name));
console.log(result);
嵌套对象检查
对于递归地检查项目所需的嵌套对象检查,我使用之前创建的这个实用程序调用
deepCompare
是罗达什的替代品
isEqual
只有880磅重
var check = [
{
name: 'Peter',
location: {
street: "fridtjof nansens vei 8511",
city: "Ã¥gotnes",
state: "buskerud",
postcode: "8766",
coordinates: {
latitude: "50.4828",
longitude: "-84.6920"
}
}
},
{
name: 'Robert',
location: {
street: "schillerstraÃe 69",
city: "velburg",
state: "saarland",
postcode: 72100,
coordinates: {
latitude: "30.4655",
longitude: "9.1938"
}
}
}
];
var allowed = [
{
name: 'Robert',
location: {
street: "schillerstraÃe 69",
city: "velburg",
state: "saarland",
postcode: 72100,
coordinates: {
latitude: "30.4655",
longitude: "9.1938"
}
}
}
];
var result = check.filter(checkPerson => allowed.some(allowPerson => deepCompare(checkPerson, allowPerson)));
console.log(result);
<script>
/**
* Deep Compare
* @param { * } value first entry value
* @param { * } other second entry value
* @param { Boolean } sorted Sort any array before deep comparison
*/
const deepCompare = (value, other, sorted) => {
/**
* Compare possible primitives
* Object.is works like `===` but additionally differes positive from negative values
* I.E:
* Object.is(-0, 0) // False
* -0 === 0 // True
*/
if (Object.is(value, other)) return true;
/**
* Check if either value is undefined or the constructor is different for each value
* given the case return false
*/
if (!value || !other || value.constructor !== other.constructor) return false;
/**
* Check Object and Array deep comparisons
*/
switch (value.constructor) {
case Array:
/**
* Check if both values have the same amount of items
* if they don't immediatelly omit the comparison and return false
*/
if (value.length === other.length) { return deepArrayCompare(value, other, sorted); }
return false;
case Object:
/**
* Check if both values have the same amount of keys
* if they don't immediatelly omit the comparison and return false
*/
if (Object.keys(value).length === Object.keys(other).length) { return deepObjectCompare(value, other, sorted); }
return false;
}
return false;
};
/**
* Deep Object Compare
* @param { * } value first entry value
* @param { * } other second entry value
*
* 'deepArrayCompare(Object.keys(value), Object.keys(other), sorted)'
* This checks that both objects have the same keys
* I.E:
* deepArrayCompare(Object.keys({ a: 1, b: 2, c:3 }), Object.keys({ a: 10, b: 22, c: 54 }), true) // True
* deepArrayCompare(Object.keys({ a: 1, b: 2, c:3 }), Object.keys({ g: 1, f: 2, d: 3 }), true) // False
*
* 'Object.keys(value).every(key => deepCompare(value[key], other[key]))'
* This iterates on each key of the object over a 'every' comparison and performs a deepCompare on both values
*
*/
const deepObjectCompare = (value, other) => deepArrayCompare(Object.keys(value), Object.keys(other), true) && Object.keys(value).every(key => deepCompare(value[key], other[key]));
/**
* Deep Array Compare
* @param { * } value first entry value
* @param { * } other second entry value
* @param { Boolean } sorted Sort any array before deep comparison
*
* '(sorted && value.sort(), sorted && other.sort(), ...)'
* This manages the optional sorting through Comma Operator
*
* 'value.every((item, index) => deepCompare(item, other[index]))'
* This performs the deepComparison of values between both arrays
*/
const deepArrayCompare = (value, other, sorted) => (sorted && value.sort(), sorted && other.sort(), value.every((item, index) => deepCompare(item, other[index])));
</script>
|