以下是一个比较两个JavaScript对象并根据条件移动数据的解决方法的代码示例:
// 比较两个对象的函数
function compareObjects(obj1, obj2) {
// 比较对象的属性是否相等
for (let prop in obj1) {
if (obj1.hasOwnProperty(prop) && obj2.hasOwnProperty(prop)) {
if (obj1[prop] !== obj2[prop]) {
return false;
}
}
}
return true;
}
// 移动数据的函数
function moveData(sourceObj, destObj, conditionFn) {
// 遍历源对象的属性
for (let prop in sourceObj) {
if (sourceObj.hasOwnProperty(prop)) {
// 检查条件函数是否满足
if (conditionFn(sourceObj[prop])) {
// 将属性从源对象移动到目标对象
destObj[prop] = sourceObj[prop];
delete sourceObj[prop];
}
}
}
}
// 示例对象
let obj1 = {name: 'John', age: 30, city: 'New York'};
let obj2 = {name: 'John', age: 30, city: 'Los Angeles'};
let obj3 = {name: 'Alice', age: 25, city: 'San Francisco'};
// 比较两个对象
console.log(compareObjects(obj1, obj2)); // 输出: true
console.log(compareObjects(obj1, obj3)); // 输出: false
// 移动数据的条件函数
function isCityNewYork(city) {
return city === 'New York';
}
// 移动数据
moveData(obj1, obj2, isCityNewYork);
// 输出移动后的结果
console.log(obj1); // 输出: {}
console.log(obj2); // 输出: {name: 'John', age: 30, city: 'New York'}
在上面的代码中,我们首先定义了一个compareObjects
函数,用于比较两个对象的属性是否相等。然后我们定义了一个moveData
函数,它接受一个源对象和一个目标对象,并根据条件函数移动数据。moveData
函数遍历源对象的属性,检查条件函数是否满足,如果满足则将属性从源对象移动到目标对象,并删除源对象中的属性。最后我们提供了一个示例对象和一个条件函数来演示如何使用这些函数。